写之前我们先问几个问题,什么是uml、 什么是类图、为什么要画类图,简单解释如下,具体在类中的关系会已小demo的方式讲解。
什么是uml: uml是统一建模语言
类图是什么:类图(Class Diagram)是面向对象系统建模中最常用和最重要的图,是定义其它图的基础。类图主要是用来显示系统中的类、接口以及它们之间的静态结构和关系的一种静态模型。
为什么学习画类图:画类图就是为了说明类和类,类和接口之间的关系,在没写代码前就能清晰看到类-类、类-接口之间的关系,而且使用类图能用简单的图形说明复杂的关系,简洁快速。
类与类之间的关系有哪些:泛华(继承)(generalization,extends)、实现(Realization)、关联(Association)、聚合(Aggregation)、组合(Composition)、依赖(Dependency)。
下面我们就以小demo的方式来学习什么是类图,类图有哪些组件组成、类与类之间的各种关系是用什么来表示的以及这些关系在具体的代码中是怎么个引用关系。
1、类图的基本组件
类图有3个基本组件:类名、属性、方法
2、泛化关系:
泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。
【箭头指向】:带三角箭头的实线,箭头指向父类
3、实现关系:
实现(Realization):在类图中就是接口和实现的关系。
【箭头指向】:带三角箭头的虚线,箭头指向接口
4、依赖关系:
依赖(Dependency):对象之间最弱的一种关联方式,是临时性的关联。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。
【箭头及指向】:带箭头的虚线,箭头从使用类指向被依赖的类,从使用者指向被使用者。
【代码表现】:局部变量、方法的参数或者对静态方法的调用.
5、关联关系:
关联(Association) : 是一种拥有的关系,它使一个类知道另一个类的属性和方法;如:老师与学生,丈夫与妻子关联可以是双向的,也可以是单向的。双向的关联可以有两个箭头或者没有箭头,单向的关联有一个箭头。
【箭头及指向】:带普通箭头的实心线,指向被拥有者
【代码体现】:成员变量
6、聚合关系:
聚合(Aggregation) : 表示has-a的关系,是一种不稳定的包含关系。较强于一般关联,有整体与部分的关系,并且没有了整体,部分也可单独存在。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司,如车和轮胎是整体和部分的关系,轮胎离开车仍然可以存在。
聚合关系是关联关系的一种,是强的关联关系;关联和聚合在语法上无法区分,必须考察具体的逻辑关系。
【箭头及指向】:带空心菱形的实心线,菱形从部分指向整体。
【代码体现】:成员变量在类图使用空心的菱形表示,菱形从局部指向整体。
Company (公司) 整体 staff (员工) 菱形从部分指向整体即从员工到公司。
7、组合关系:
组合(Composition) : 表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。
【箭头及指向】:带实心菱形的实线,菱形从部分指向整体
【代码体现】:成员变量
其中的公司整体,部门部分菱形从部门指向公司,问卷和选项一样,其中选项是部分而问卷是整体,没了问卷选项也就不存在了,实心菱形箭头从部分指向整体。
这两个比较难理解,重点说一下。聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。
下面看看类图的例子:
1、实例1
2、实例2
看这个涉及到的关系比相对较多。