1、定义
简而言之,对于合成/聚合复用原则的定义就是:要尽量使用合成和聚合,尽量不要使用继承。
2、释义
为什么“要尽量使用合成和聚合。尽量不要使用继承”呢?
这是由于:
第一,继承复用破坏包装,它把父类的实现细节直接暴露给了子类,这违背了信息隐藏的原则;
第二:假设父类发生了改变。那么子类也要发生对应的改变。这就直接导致了类与类之间的高耦合,不利于类的扩展、复用、维护等,也带来了系统僵硬和脆弱的设计。
而用合成和聚合的时候新对象和已有对象的交互往往是通过接口或者抽象类进行的,就能够非常好的避免上面的不足。并且这也能够让每个新的类专注于实现自己的任务,符合单一职责原则。
3、何时使用合成/聚合、继承
两种推断方法:
1)、使用“Has-A”和“Is-A”来推断
“Is-A”代表一个类是另外一个类的一种。能够使用继承关系,例如以下图
而“Has-A”代表一个类是另外一个类的一个角色,而不是另外一个类的特殊种类。
例如以下图
2)、使用里氏代换原则来推断
里氏代换原则是继承复用的基础。
详细介绍:设计模式六大原则——里氏代换原则