UML类图
统一建模语言 (Unified Modeling Language,UML) 是用来设计软件的可视化建模语言。它的特点是简单、统一、图形化、能表达软件设计中的动态与静态信息。UML 从目标系统的不同角度出发,定义了用例图、类图、对象图、状态图、活动图、时序图、协作图、构件图、部署图等 9 种图。
总结
UML 类途中常见的几种关系:
- 泛化 (Generalization):继承关系
- 实现 (Realization):实现接口,类与接口的关系,implements
- 关联 (Association):拥有的关系,单项关联(单项箭头 ),双向关联(无箭头),自身关联
- 聚合 (Aggregation):整体与部分,比如:人 - 手,脚的关系
- 组合 (Composition):整体与部分,是关联关系的一种,比聚合关系还要强的关系,如:构造函数中初始化的成员变量
- 依赖 (Dependency):是一种使用关系,尽量不要双向依赖,如:局部变量,方法的参数
各种关系的强弱程度:
泛化(继承) = 实现 > 组合 > 聚合 > 关联 > 依赖关联、聚合和组合关系最大的区别在于对象的生命周期:
- 关联关系: 每个对象都有自己的生命周期,对象之间不存在从属关关系
- 聚合关系: 整体和部分是可以分离的,整体和部分都可以拥有各自的生命周期
- 组合关系: 整体和部分是不可以分离的,整体的生命周期结束时,也意味着部分的生命周期结束。
类的表示方式
普通类
在 UML 类图中,类包含:类名,属性(field)和方法(method)且带有分割线的矩形来表示,如:
访问权限:
-
: 表示 private#
: 表示 protected(friendly)+
: 表示 public
属性的完整表示方式是: 名称: 类型[=缺省值]
方法的完整表示方式是:名称(参数列表)[: 返回类型]
抽象类
在 UML 类图中
- 抽象类类名称用斜体表示,抽象方法用斜体表示
- 类图边框用虚线表示 (建议)
接口
在 UML 类图中
- 接口名称用斜体表示,抽象方法用斜体表示
- 接口取消属性栏 (建议)
类的关系表示方式
泛化关系(继承)
理解:继承关系
继承关系是对象之间耦合度最大的一种关系,表示一般与特殊的关系,是父类与子类之间的关系,是一种继承关系。
表示:空心三角箭头实线,子类指向父类
实现关系(接口)
理解:实现接口关系
表示:接口关系表示类和接口之间的关系,它的符号(空心三角形 + 虚线)
关联关系
理解:关联关系是一种拥有关系
表示:成员变量,可以是单向,双向,也可以说自我关联。
符号:
单向关联:带普通箭头,指向被拥有者的实线
双向关联:没有箭头的实线
自关联:带有箭头,指向自身的实线
聚合关系
理解:是关联关系的一种,是强关联关系(整体与部分的关系),比如人和手、脚的关系。整体和部分是可以分离的,整体和部分都可以拥有各自的生命周期。
关联和聚合在语法上无法区分,必须考虑具体的逻辑关系.
表示:成员变量,带空心菱形的实心线,菱形指向整体
组合关系
理解:组合表示类之间的整体与部分的关系,但它是一种更强烈的聚合关系。
在组合关系中整体对象可以控制部分对象的主命周期,整体和部分是不可以分离的,整体的生命周期结束时,也意味着部分的生命周期结束。
符号:实心菱形 + 实线
依赖关系
理解:字面意思就是依赖关系,比如人依赖汽车:
依赖关系是一种使用关系,它是对象之间耦合度最弱的一种关联方式,是临时性的关联。在代码中,某个类的方法通过局部变量方法的参数或者对静态方法的调用来访问另一个类(被依赖类)中的某些方法来完成一些职责。
符号:虚线箭头,箭头指向为被依赖方 (被使用者)