UML类图基本图示法
UML类图基本图示法
我的总结
继承(Is-A)三角箭头
实现关系,使用带空心(三角形)箭头的虚线表示
泛化关系,使用带空心箭头的实线表示
关联(Has-A)菱形箭头
合成(复合)关系,使用带空心(棱形)箭头的实线表示
1 |
|
聚合关系,使用带空心箭头的实线表示(鸟群)
关联关系,使用一根实线表示
1 |
|
依赖(Use-A)
依赖关系,使用带箭头的虚线表示
//注意动物是抽象类
1 |
|
一、概述
UML类图是在面向对象的程序设计中,用来直观描述类与类之间、类与接口之间的关系的图,在面向对象软件的设计与搭建阶段起着关键作用。下图为一幅示例UML类图,其展示了UML类图中的基本图示。
二、类与接口的表示方法
在类图示例中,总共有两种主体:类和接口。在UML类图中,有固定的类和接口的表达方式,如下图所示:
三、类与类、类与接口之间的关系
基本的关系总共有六种:继承、实现接口、关联、聚合、复合、依赖。UML类图通过使用不同的连接线对这6种关系进行区分。
不同关系的连接线样式
1、继承关系
类A继承类B,意思是说类B是类A的更高一层抽象,此时它们的关系可以通过继承关系表示。就如同鸟和动物的关系,动物是鸟的更高一层抽象,此时我们说鸟继承自动物,于是可以如下表示:
实装到代码即会是如下形式:
1 |
|
2、接口实现关系
类A中实现了接口B中的所有方法,我们称类A与B为接口实现关系。以大雁类和飞翔接口为例,因为并不是所有鸟类都会飞,所以飞翔被抽象成接口,只有会飞的鸟才需要实现它,因此大雁类需要实现飞翔这个接口,它们就是接口实现关系,如下图所示:
实装到代码即会是如下形式:
1 |
|
3、关联关系
当类A需要从类B那得到信息或者调用类B的的方法时,我们称类A与类B为关联关系。比如企鹅迁徙时需要得知气候信息,故企鹅类与气候类会有关联关系,如下图所示:
实装到代码就是这个样子:
1 |
|
4、聚合关系
当类A由多个类B聚合而成,我们称它们满足聚合关系。以大雁类和雁群类为例,雁群由多只大雁组成,这就是聚合。“_聚合是一种弱的拥有‘关系’,体现就是A对象可以包含B对象,但B对象不是A对象的一部分”_——《设计模式解析》(第二版)。同样以大雁举例,大雁不会因为离开雁群就不能独自存在下去,即大雁可以脱离雁群独立存在,不会因为雁群的解散就死亡,这就是雁群对于大雁的弱的拥有关系。这与后面的“复合关系”是形成鲜明对比的,聚合关系如下图所示:
实装到代码是这个样子:
1 |
|
5、复合关系
复合关系可以看成聚合关系的加强版。_“复合时一种强的‘拥有’关系,体现了严格的部分和整体的关系,部分和整体的生命周期一样”_——《设计模式解析》(第二版) 。拿鸟和翅膀的关系举例,鸟和翅膀的生命周期是相同的(鸟死了,翅膀也会失去生命力),所以鸟和翅膀是复合关系,同时一只鸟具有两只翅膀,这也可以通过在复合连接线两端添加被称为“基数”的数字表现出来,如下图所示:
实装到代码就是这个样子:
1 |
|
6、依赖关系
“动物几大特征,比如有新陈代谢,能繁殖。而动物要有生命力,需要氧气、水以及食物等。也就是说,动物依赖于氧气和水。它们之间是依赖关系(Dependency)”——《大话设计模式》。一般来说,当类A关联类B,类B的引用一般会在类A中作为全局变量出现;而类A依赖类B,类B一般会在类A的方法中作为形参出现。依赖关系如下图所示:
表现为代码,就是下面这个样子:
1 |
|