在Java中,类之间有各种关系,例如:继承、实现、依赖、关联、聚合、组合。尤其关联、聚合、组合之间的区别,本文将详细讲述。
1)继承(Extends)
继承是面向对象最显著的一个特性。继承是从已有类(父类、父接口)中派生出新的类(子类、子接口),新的类能集成父类(或父接口)的属性和行为,并能扩展新的能力。在Java中此类关系通过关键字extends标识。
一般使用一个带空心箭头的实线标识集成关系,UML图表示如下:
2)实现(Implements)
实现是类和接口之间最常见的关系。指的是一个类实现接口的功能(一个类可以实现多个接口),在Java中此类关系通过关键字implements标识。
一般用一个带空心箭头的虚线表示实现关系,UML图表示如下:
3)依赖(Dependency)
依赖关系是指一个类对另一个类的依赖。种种关系是非常弱、临时性的关系。依赖关系在Java中体现为:局域变量、方法的形参,或者对静态方法的调用。
一般使用一条指向被依赖对象的虚线表示依赖关系,UML图标识如下:
例如:ClassA中有个方法function(ClassB classB),这个方法的形参为:ClassB,那么可以说ClassA依赖ClassB这个类,如果ClassB发生了变化那么会对ClassA这个类造成影响。如上图。
4)关联(Association)
关联关系是类与类之间的联结,它使一个类知道另一个类的属性和方法。关联可以是双向的,也可以是单向的,它是依赖关系更强的一种关系。
在Java语言中,关联关系一般表现为被关联类B以属性的形式出现在关联类A中,也可能是关联A引用了一个类型为被关联类B的全局变量;
一般用实线关联(单向关联实线箭头,双向关联为实线)的两个类,UML图标识如下:
5)聚合(Aggregation)
聚合是一种特殊的关联关系,它是较强的一种关联关系,强调的是整体与部分之间的关系,从语法上是没办法区分的,只能从语义上区分。
聚合的整体和部分之间在生命周期上没有什么必然的联系,部分对象可以在整体对象创建之前创建,也可以再整体对象销毁之后销毁。例如:雁群和大雁的关系、学校和学生的关系,大雁和雁群、学生和学校之间的生命周期没有必然联系。
一般用带一个空心菱形的实线箭头标识(菱形指向整体),UML图标识如下:
6)组合(Composition)
组合也是关联关系的一种特例,这种关系比聚合关系更强。它强调了整体与部分的生命周期是一致的,而聚合的整体和部分之间在生命周期上没有什么必然的联系。整体与部分是关系紧密,生命周期一致。
例如:大雁和大雁翅膀是组合关系。
一般使用实心菱形的实现箭头标识。UML图标识如下:
总结
1)集成、实现,两种关系比较简单,表示的是类与类、接口与接口之间的纵向关系;
2)依赖、关联、聚合、组合,则表示的是类与类、类与接口之间的引用、横向关系。这几种关系表现的强弱程度一次为:依赖 < 关联 < 聚合 < 组合