依赖 (use - a) Dependency
依赖关系是类与类之间的联接,依赖关系表示一个类依赖于另一个类的定义。一般而言,依赖关系在Java语言中体现为局域变量、方法的形参,或者对静态方法的调用。
简单的理解,依赖就是一个类A使用到了另一个类B(可以理解为使用关系,被依赖的对象只是作为一种工具在使用,而不是持有对它的引用),这种使用关系是具有偶然性的、临时性的(事情做完立即解散)、非常弱的,但是类B的变化会影响到类A。比如某人要过河,需要借用一条船,此时人与船之间的关系就是依赖(人可以乘船过河,但是船不是这个人的,人只是使用了这个船,使船移动)。
表现在代码层面,为类B作为参数被类A在某个方法中使用。
Java程序体现的形式为:
一个类用到了另一个类的对象;
第一个可以在方法中传递参数;
第二个可以在方法中自己创建;
包含(has - a ) ---- 组合、聚合、关联
关联关系(Association):
关联关系是类与类之间的联接,它使一个类知道另一个类的属性和方法,关联关系体现的是两个类之间语义级别的一种强依赖关系,一般是长期性的,而且双方的关系一般是平等的。关联可以是双向的,也可以是单向的。在Java语言中,关联关系一般使用成员变量来实现。
举例:人有电脑,人有汽车,整体和部分的关系,通过一个类当另一个类的属性来存储。
表现在代码层面,为被关联类B以类的属性形式出现在关联类A中,也可能是关联类A引用了一个类型为被关联类B的全局变量。
组合关系(Composition):
组合是关联关系的一种(特例),是比聚合关系强的关系。它要求普通的聚合关系中代表整体的对象负责代表部分对象的生命周期,组合关系是不能共享的。代表整体的对象需要负责保持部分对象和存活,在一些情况下将负责代表部分的对象湮灭掉。代表整体的对象可以将代表部分的对象传递给另一个对象,由后者负责此对象的生命周期。换言之,代表部分的对象在每一个时刻只能与一个对象发生组合关系,由后者排他地负责生命周期。部分和整体的生命周期一样。
举例:人和大脑、人和心脏的关系,整体和部分的关系,不可分割,要出现都出现 要消亡都消亡。
表现在代码层面,和关联关系是一致的,只能从语义级别来区分。
聚合关系(Aggregation):
聚合关系是关联关系的一种,是强的关联关系。聚合是整体和个体之间的关系。与关联关系一样,聚合关系也是通过实例变量实现的,但是关联关系所涉及的两个类是处在同一层次上的,而在聚合关系中,两个类是处在不平等层次上的,一个代表整体,另一个代表部分。
举例:汽车类与引擎类、轮胎类,以及其它的零件类之间的关系便整体和个体的关系,创建时可能是分开的。
表现在代码层面,和关联关系是一致的,只能从语义级别来区分。
依赖 < 关联 < 聚合 < 组合
设计类的关系遵循的原则:高内聚低耦合
耦合度: 紧密 继承(实现) > 包含 > 依赖
小练习:
1.模拟一个学生在机房内使用电脑的例子
有一个机房
有一台电脑 电脑有开机/关机的状态 电脑被打开 被使用中 被关闭
有一个学生 使用电脑
让学生进入机房 使用电脑
扩展: 机房内放置5台电脑 让学生进入机房选择一台关闭的电脑使用
学生也有5个 陆续进入机房
2.模拟一个警车 小汽车 测速器之间的关系
测速器测量小汽车的速度 100米5秒钟 标准
如果小汽车超速 警车追击
如果警车追击成功 输出追击时间
如果警车追不上 输出追不上啦