复用的基本种类:
合成/聚合复用 :
优点:
* 新对象存取成分对象的唯一方法是通过成分对象的接口。
* 这种复用是黑箱复用,因为成分对象的内部细节是新对象所看不见的。
* 这种复用支持包装。
* 这种复用所需的依赖较少。
* 每一个新的类可以将焦点集中在一个任务上。
* 这种复用可以在运行时间内动态进行,新对象可以动态的引用与成分对象类型相同的对象。
缺点:
* 系统中会有比较多的对象需要管理。
通过继承的复用:
合成/聚合作为复用手段可以应用到几乎任何环境中去,而继承只能在有限的环境中使用。尽管继承是一种非常重要的复用手段,但应当首先考虑合成/聚合,而不是继承。
优点:
* 新的实现较为容易,因为超类的大部分功能可以通过继承的关系自动进入子类。
* 修改和扩展继承而来的实现较为容易。
缺点:
* 继承复用破坏包装,因为继承将超类的实现细节暴露给子类。由于超类的内部细节常常是对于子类透明的,所以这种复用是透明的复用,又称“白箱”复用。
* 如果超类发生改变,那么子类的实现也不得不发生改变。
* 从超类继承而来的实现是静态的,不可能在运行时间内发生改变,没有足够的灵活性。