六种常见的关系以及耦合强度:依赖 < 关联 < 聚合 < 组合 < 实现 <继承
1、依赖关系(Dependency),仅仅是依赖而已,不强制拥有
关系描述:use a;一个对象A 在 运行期间 会 用到 另一个对象B的关系;属于一种临时关系,方法调用结束时,彼此的依赖关系也就结束了。
代码形式:类方法的参数或者返回值,或者某个方法里面的临时变量、局部变量、静态方法调用等。
注:理论上,存在双向依赖关系,此种关系彼此依赖,耦合性高,应该避免。
2、关联关系(Association),关联关系所涉及的两个类是处在同一层次上的。
关系描述:has a;表示类与类之间的联接,一个对象A 包含或者拥有 另一个对象B的关系;属于一种静态的结构上的关系,属于“强关联”的关系;包括单向关联和双向关联。
代码形式:类的成员变量
注:1、关联关系可以细分为聚合关系和组合关系。
2、双向关联关系是允许的,但需要特殊注意,在OC中极可能引起循环引用。
3、聚合关系(Aggregation),是一种强的关联关系。不同类聚集在一起合成一个整体类,生命周期彼此独立。
关系描述:用于表示实体对象之间的关系,表示整体由部分构成的语义,但是彼此可以独立存在,各自有自己的生命周期。例如一个部门由多个员工聚合组成。
代码形式:类的成员变量,一般为了表示聚合关系,常常会使用setter方法给成员变量赋值。
4、组合关系(Composition),是一种更强的关联关系。整体类由部分类构成,生命周期一样。
关系描述:表示整体由部分构成的语义,彼此生命周期一样,如果整体不存在了,则部分也不存在了。例如公司由多个部门组成。
代码形式:类的成员变量,一般为了表示组合关系,常常会使用构造方法来达到初始化的目的。
5、泛化关系(Generalization),即类继承
关系描述:is a,例如自行车是车、猫是动物。
代码形式:类的继承
6、实现关系(Realization),即接口实现,抽象类实现
关系描述:implement a
代码形式:接口、抽象类的实现
汇总:
参考资料:
http://design-patterns.readthedocs.io/zh_CN/latest/read_uml.html