区分 UML 类图中的几种关系
UML 类图中的 ”关联关系(association) “、”聚合关系(aggregation) “、”合成关系 (compostion)“ 和”依赖关系 (dependency)“ 不是很容易区分清楚,《UML distilled》 对这几个关系也没有解释的特别清楚。近日翻阅《Java 与模式》,发现其中对这些关系有较为清晰的描述,特摘录如下:

关联关系 (association)

(1)关联关系是类与类之间的联结,它使一个类知道另一个类的属性和方法。
(2)关联可以是双向的,也可以是单向的。双向的关联可以有两个箭头或者没有箭头,单向的关联有一个箭头。
(3)在 Java 或 c++ 中,关联关系是通过使用成员变量来实现的。

 
  
  1. class 徒弟   
  2. { };   
  3. class 唐僧   
  4. {   
  5.  protected list<徒弟> tdlist;   
  6. };  


1

聚合关系 (aggregation)

1、聚合关系是关联关系的一种,是强的关联关系。
2、聚合是整体和部分之间的关系,例如汽车由引擎、轮胎以及其它零件组成。
3、聚合关系也是通过成员变量来实现的。但是,关联关系所涉及的两个类处在同一个层次上,而聚合关系中,两个类处于不同的层次上,一个代表整体,一个代表部分。
4、关联与聚合仅仅从 Java 或 C++ 语法上是无法分辨的,必须考察所涉及的类之间的逻辑关系。
 

 
  
  1. class 引擎   
  2. {   
  3. };   
  4. class 轮胎   
  5. {   
  6. };   
  7. class 汽车   
  8. {   
  9. protected:   
  10. 引擎 engine;   
  11. 轮胎 tyre[4];   
  12. };  


2

合成关系 (composition):

1、合成关系是关联关系的一种,是比聚合关系还要强的关系。
2、它要求普通的聚合关系中代表整体的对象负责代表部分的对象的生命周期。
 

 
  
  1. class 肢 {   
  2. };   
  3. class 人{   
  4. protected:   
  5. 肢 limb[4];   
  6. };  

3

依赖关系 (dependency):

1、依赖关系也是类与类之间的联结
2、依赖总是单向的。
3、依赖关系在 Java 或 C++ 语言中体现为局部变量、方法的参数或者对静态方法的调用。

显示代码打印

 
  
  1. public class Person   
  2. {   
  3. public void buy(Car car)   
  4. { ... }   
  5. }  


4

总结:

1、不同的关系采用不同的 UML 图例
2、对于聚合关系、合成关系,由于都是关联关系的一种,因此在不确定的情况下,可以以关联关系来描述它们。