您的位置:首页 > 其它

UML类图与类之间的关系

2015-05-12 15:52 246 查看

UML类图

类之间的关系

泛化:Generalization

实现:Realization

依赖:Dependency

关联:Association

聚合关系:Aggregation

合成关系:Composition

按图说“理”

类图

主要是用来显示系统中的类、接口以及它们之间的静态结构和关系的一种静态模型,是其它图的基础。每一个类图由类名、属性、方法组成。



泛化

表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。



使用带空三角箭头的实线表示,箭头从子类指向父类。

实现

及接口和其实现的关系



使用带空三角箭头的虚线表示,箭头从实现类指向接口。

依赖

对象之间最弱的一种关联方式,是临时性的关联。代码中一般指局部变量、函数参数、返回值建立的对其他对象的调用关系。简单的说就是一个类调用了被依赖类中的某些方法而完成这个类的一些职责。



使用虚线箭头表示,指向被依赖类。

关联

对象之间的一种引用关系,通常这种关系通过类的属性表达。关联又分为一般关联、聚合关联与组合关联。后两种在后面分析。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。



聚合(Aggregation)

表示has-a的关系,是一种不稳定的包含关系。较强于一般关联,有整体与局部的关系,并且没有了整体,局部也可单独存在。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。在类图使用空心的菱形表示,菱形从局部指向整体。



组合(Composition) :

表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。



多重性(Multiplicity) :

通常在关联、聚合、组合中使用。就是代表有多少个关联对象存在。使用数字..星号(数字)表示。如下图,一个割接通知可以关联0个到N个故障单。



聚合和组合的区别

聚合和组合的区别在于:

聚合关系是“has-a”关系,组合关系是“contains-a”关系;

聚合关系表示整体与部分的关系比较弱,而组合比较强;

聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。

实例分析

联通客户响应OSS。系统有故障单、业务开通、资源核查、割接、业务重保、网络品质性能等功能模块。现在我们抽出部分需求做为例子讲解。

1. 通知分为一般通知、割接通知、重保通知。这个是继承关系

2. NoticeService和实现类NoticeServiceImpl是实现关系。

3. NoticeServiceImpl通过save方法的参数引用Notice,是依赖关系。同时调用了BaseDao完成功能,也是依赖关系。

4. 割接通知和故障单之间通过中间类(通知电路)关联,是一般关联。

5. 重保通知和预案库间是聚合关系。因为预案库可以事先录入,和重保通知没有必然联系,可以独立存在。在系统中是手工从列表中选择。删除重保通知,不影响预案。

6. 割接通知和需求单之间是聚合关系。同理,需求单可以独立于割接通知存在。也就是说删除割接通知,不影响需求单。

7. 通知和回复是组合关系。因为回复不能独立于通知存在。也就是说删除通知,该条通知对应的回复也要级联删除。

原文引自:http://www.uml.org.cn/oobject/201104212.asp

写的很详细,个人拿来后整理,如有问题,会及时改正。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: