泛化(Generalization)
什么时候需要泛化
- 子类需要增加新的属性
- 子类需要增加新的关联
- 子类需要进行与其他子类不同的操作、反应、控制等
- 子类需要表示一种生物,来进行与父类或其他子类不同的行为和动作
注意:不要过分的颗粒化。如下图这样:
抽象概念类
下图中,若存在Payment的实例既不是CashPayment,也不是CreditPayment,也不是CheckPayment,那么Payment就不是抽象概念类。反之则是。
抽象概念类在UML中
用斜体表示。以上图为例:
依赖(Dependency)
对象之间最弱的一种关联方式,是临时性的关联。它表示一个瞬时的关系。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。

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

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

组合(Composition)
表示is-a-part-of的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。
本文详细解析了UML中的六种类关系:泛化、实现、依赖、关联、聚合与组合,介绍了每种关系的特点及应用场景,并区分了聚合与组合的不同。


1001

被折叠的 条评论
为什么被折叠?



