UML类图关系

来源:互联网 发布:诸城网络推广报价 编辑:程序博客网 时间:2024/06/05 05:01

•UML中的关系(Relationships)主要包括4种:关联关系、依赖关系、泛化关系和实现关系。

  

关联关系(Association)

•关联关系是一种结构化的关系,指一种对象和另一种对象有联系。给定关联的两个类,可以从其中的一个类的对象访问到另一个类的相关对象。

•在UML图中,关联关系用一条实线表示。
 
 依赖关系(Dependency)
•对于两个对象X、Y,如果对象X发生变化,可能会引起对另一个对象Y的变化,则称Y依赖于X。
•在UML图中,依赖关系用一条带有箭头的虚线来表示。

 

  

泛化关系(Generalization)

•UML中的泛化关系定义了一般元素和特殊元素之间的分类关系,与和C++及Java中的继承关系有些类似。
•在UML图中,泛化关系用一条带有空心箭头的实线来表示。

 

 

实现关系(Realization)

•实现关系将一种模型元素(如类)与另一种模型元素(如接口)连接起来,其中接口只是行为的说明而不是结构或者实现。真正的实现由前一个模型元素来完成。
•在UML图中,实现关系一般用带有一条带有空心箭头的虚线来表示 。

 

 

区分 UML  类图中的几种关系

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

 

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


class 徒弟 

2 { 

3 }; 

4   

5 class 唐僧 

6 { 

7 protected: 

8           list<徒弟>  tdlist; 

9 };

 

 


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


class 引擎 

02 { 

03 }; 

04   

05 class 轮胎 

06 { 

07 }; 

08   

09 class 汽车 

10 { 

11 protected: 

12     引擎  engine; 

13     轮胎  tyre[4]; 

14 };

 

 

 

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


class 肢 

2 { 

3 }; 

4   

5 class 人 

6 { 

7 protected: 

8      肢   limb[4]; 

9 };

 

 一般是实心菱形加实线箭头表示

 


 

4、依赖关系 (dependency):
      1、依赖关系也是类与类之间的联结
      2、依赖总是单向的。(#add  注意,要避免双向依赖。一般来说,不应该存在双向依赖。)
      3、依赖关系在 Java 或 C++ 语言中体现为局部变量、方法的参数或者对静态方法的调用。

class Person 

2 { 

3      void buy(Car car)  

4      { 

5          ... 

6      } 

7 }

 

 虚线加箭头


 

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