UML类图符号总是记不牢,容易混淆,在此梳理,以便更加容易记忆。
语法层面
泛化和实现
泛化和实现表示的是类之间是上下层级的关系。
- 泛化:在java语法中用继承体现。
- 实现:即实现接口的意思,各个语言都是通用的。
辅助记忆法:两者共同点都是用三角形表示,区别在于连接线的虚实,接口一般只有定义,所以没有具体执行体,所以比较虚,所以用虚线表示;而继承的父类一般都有共同代码,所以是比较实的,所以用实线表示。
关联和依赖
关联和依赖是表示类之间是平行层级的关系。
- 关联:表示类与类是强关联关系,比如类A关联类B,那么类B作为类A的属性的方式表示。
- 依赖:表示类与类是弱关联关系,比如类A依赖类B,那么类B作为类A中某个方法的参数的方式表示。
辅助记忆法:两者共同点都是用箭头表示,区别在于连接线的虚实,关联是一种强关联,所以用实线表示;而依赖是弱关联,所以用虚线表示。注意箭头指向:关联谁,就指向谁;依赖谁,就指向谁。
关联:
依赖:
语义层面
聚合和组合
从语法层面上,泛化、实现、关联和依赖已经可以完整表示类之间的关系。但是为了更加方便理解类的关系,针对关联在语义层面上细分成两种关系,那就是聚合和组合。
- 聚合(Aggregation):表示整体和部分只是组装在一起,生命周期并不进行关联,有各自的生命周期。还有,多个整体可以共享多个部分,比如老师和学生,一个老师可以是很多学生的老师,同样一个学生也可以是很多老师的学生。
- 组合(Composition):表示整体和部分是一体的,生命周期同步,所谓唇亡齿寒。比如身体和头、手就是组合关系。
辅助记忆法:整体和部分,整体就比较大,而菱形看起来比较大,所以用它表示比较合适。因为两者都是关联关系,所以连接线都是实线,两者区别在于菱形是否空心,聚合的整体和部分生命周期不同步,用空心;而组合的整体和部分生命周期同步,用实心更加合适。注意:关联关系有个箭头,但是在聚合和组合时,那个箭头可有可无,以下两种方式都可以。