UML类图-基本关系概念

类关系说明:

类的关系有泛化(Generalization)、实现(Realization)、依赖(Dependency)和关联(Association)。
其中关联又分为一般关联关系和聚合关系(Aggregation),合成关系(Composition)。
各种关系的强弱顺序:泛化 = 实现 > 组合 > 聚合 > 关联 > 依赖 ;


基本概念:

泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。在类图中使用带三角箭头的实线表示,箭头从子类指向父类。
【箭头指向】:带三角箭头的实线,箭头指向父类 

实现(Realization):在类图中就是接口和实现的关系。这个没什么好讲的。在类图中使用带三角箭头的虚线表示,箭头从实现类指向接口。 
【箭头指向】:带三角箭头的虚线,箭头指向接口


依赖(Dependency):对象之间最弱的一种关联方式,是临时性的关联。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。 
【代码表现】:局部变量、方法的参数或者对静态方法的调用
【箭头及指向】:带箭头的虚线,指向被使用者


关联(Association) : 对象之间一种引用关系(一种拥有的关系,它使一个类知道另一个类的属性和方法),比如客户类与订单类之间的关系。这种关系通常使用类的属性表达。关联又分为一般关联、聚合关联与组合关联。后两种在后面分析。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。 双向的关联可以有两个箭头或者没有箭头,单向的关联有一个箭头。
【代码体现】:成员变量
【箭头及指向】:带普通箭头的实心线,指向被拥有者
 


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

【代码体现】:成员变量
【箭头及指向】:带空心菱形的实心线,菱形指向整体


组合(Composition) : 表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。 
【代码体现】:成员变量
【箭头及指向】:带实心菱形的实线,菱形指向整体


多重性(Multiplicity) : 通常在关联、聚合、组合中使用。就是代表有多少个关联对象存在。使用数字..星号(数字)表示。 


聚合和组合的区别 :
这两个比较难理解,重点说一下。聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。 


备注:
泛化 = 实现 > 组合 > 聚合 > 关联 > 依赖关系越来越弱;组合是一种强烈的包含关系,它存在的是一种contains-a的关系,组合关系部分不能脱离整体存在;聚合是一种不稳定的包含关系,它存在的是一种has-a的关系,聚合关系双方缺少任何一方都可以独立存在; 关联关系是一种引用关系;一般情况遇到关联关系应该再进一步考虑其关系是否为组合或者聚合关系;
组合关系是关联关系的一种,是比聚合关系还要强的关系,它要求普通的聚合关系中代表整体的对象负责代表部分的对象的生命周期。
聚合关系是关联关系的一种,是强的关联关系;关联和聚合在语法上无法区分,必须考察具体的逻辑关系。  



文献地址:
http://www.uml.org.cn/oobject/201104212.asp

推荐相关内容:
http://www.open-open.com/lib/view/open1328059700311.html

 


 

 

本文出自 “Bin纷世界” 博客,谢绝转载!

你可能感兴趣的:(UML,类图)