前言:
笔者最近在写软件构造方面的一个实验。这是到目前为止写过的复杂性最高的一个了。接下来会分几篇文章来介绍自己的思路以及不同的技巧知识。
一直以来,在类与类之间需要大量的复用操作以及面对增加功能这一类的需求时,我们最习惯的办法是利用继承,但由于本次实验要求对封装性有着特殊的要求,因此我发现了组合这种方法。
组合关系概述
- 实现类的复用除了继承外,还可以使用
组合
的方式,把该类当成另一个类的组合成分
,从而允许新类直接复用该类的public方法
。 - 不管继承还是组合,都允许在新类(对于继承就是子类)中直接复用旧类的方法。
- 组合是把
旧类对象作为新类的成员变量
组合起来,用以实现新类的功能
,用户看到的是新类的方法,而不能看到被组合对象的方法。因此,通常要在新类里使用private修饰被组合的旧类对象
。 -
组合和继承
-
从类的复用角度看,父类的功能等同于组合中被组合的类,都将自身的方法提供给新类使用;子类和组合关系里的整体类,都可复用原有类的方法,用于实现自身的功能。
-
继承关系中从多个子类抽象出共有父类的过程,类似于组合关系中多个整体类里提取被组合类的过程;继承关系中从父类派生子类的过程,则类似于组合关系中被组合类组合到整体类的过程。
-
何时使用组合或者继承
有一种形象的比喻:组合
是“有 has-a
”关系,继承
是“是 is-a
”关系。- 这就很形象的体现了封装性的思想,我们直接扣除了重写这一功能,看我安全不安全,哈哈哈。
-
最后的总结:
-
在软件开发阶段,组合关系的编码量没能比继承关系少,但是到了软件维护阶段,由于组合关系使系统具有较好的松耦合性,系统维护会更容易。
组合关系的缺点是比继承关系要创建更多的对象。