0%

软件设计箭头总结

[toc]

空白三角: 和类的父子关系有关#

父子关系,对应于java
就是 类的派生(泛化) ,和接口的 实现
且箭头从儿子指向父亲

img

因为接口类似于虚函数, 而类是实体,所以实现是虚线, 派生是实线(我是这么理解的,你也可以在其他角度理解强弱)

二叉箭头: 和类与类的使用关系相关#

即对于类A, 他是怎么调用B的?

java中类和类的调用关系,就2种方式:
一种是在自己的方法中,把其他类作为参数调用, 这个叫做 依赖dependency
即是由于要方法调用,才用到B的引用。用好了就再见了。

img

一种是作为私有成员或者静态成员, 去调用类对象的方法,这个叫做 关联association
即不仅要用,我还要一直持有你!

img

关联必须要持有对方类的引用, 这个依赖强度比 方法调用要强很多。
所以关联是实现, 依赖是虚线。

菱形箭头: 和类与类的包含关系相关,谁是谁的成员#

这里存在谁大谁小的关系, 菱形箭头从小的指向大的。

java种类和类的包含关系就2种情况:

  • 一种是外部import进来的类作为成员,这个叫 聚合aggregation
    B是可以独立存在的,所以是外部import进来

大家只是为了合力做一件事才在一起, 不爽了也可以出去独立做事或者给别人做势。
或者理解为把一堆同级别的事物打包,打成一个大的团体

img

注意聚合的线头为什么会带一个二叉箭头?
因为聚合一般是作为成员属性存在的,也相当于一种关联关系

img

  • 一种是内部私有类作为成员, 这个类只能内部使用,不能开放给外部去用。这个就叫 组合Compostition

即我就是你的专有零件,离开了你我就成废铁。

img

img

因为组合的依赖关系特别强,离开了就不行了,所以组合是实心的菱形箭头, 聚合是空心的菱形箭头。

类的依赖关系大小记忆#

  • 类的继承关系 > 类的包含关系 > 类的调用关系 .
    再加上实线大于虚线,实心大于空心, 就能推出一下关系:
  • 泛化(派生) = 实现 > 组合 > 聚合 > 关联 > 依赖。