定义:在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过向这些对象的委派达到复用这些对象的目的。应首先使用合成/聚合,合成/聚合则使系统灵活,其次才考虑继承,达到复用的目的。而使用继承时,要严格遵循里氏代换原则。有效地使用继承会有助于对问题的理解,降低复杂度,而滥用继承会增加系统构建、维护时的难度及系统的复杂度。
如果两个类是“Has-a”关系应使用合成、聚合,如果是“Is-a”关系可使用继承。"Is-A"是严格的分类学意义上定义,意思是一个类是另一个类的"一种"。而"Has-A"则不同,它表示某一个角色具有某一项责任。

什么是合成?什么是聚合?

合成(Composition)和聚合(Aggregation)都是关联(Association)的特殊种类。
聚合表示整体和部分的关系,表示“拥有”。如奔驰S360汽车,对奔驰S360引擎、奔驰S360轮胎的关系是聚合关系,离开了奔驰S360汽车,引擎、轮胎就失去了存在的意义。在设计中, 聚合不应该频繁出现,这样会增大设计的耦合度。
合成则是一种更强的“拥有”,部分和整体的生命周期一样。合成的新的对象完全支配其组成部分,包括它们的创建和湮灭等。一个合成关系的成分对象是不能与另一个合成关系共享的。
换句话说,合成是值的聚合(Aggregation by Value),而一般说的聚合是引用的聚合(Aggregation by Reference)。
明白了合成和聚合关系,再来理解合成/聚合原则应该就清楚了,要避免在系统设计中出现,一个类的继承层次超过3层,则需考虑重构代码,或者重新设计结构。当然最好的办法就是考虑使用合成/聚合原则。

通过合成/聚合来进行复用的优缺点

优点:

1) 新对象存取成分对象的唯一方法是通过成分对象的接口。
2) 这种复用是黑箱复用,因为成分对象的内部细节是新对象所看不见的。
3) 这种复用支持包装。
4) 这种复用所需的依赖较少。
5) 每一个新的类可以将焦点集中在一个任务上。
6) 这种复用可以在运行时间内动态进行,新对象可以动态的引用与成分对象类型相同的对象。
7) 作为复用手段可以应用到几乎任何环境中去。
缺点:就是系统中会有较多的对象需要管理。

通过继承来进行复用的优缺点

优点:
1)新的实现较为容易,因为超类的大部分功能可以通过继承的关系自动进入子类。

2)修改和扩展继承而来的实现较为容易。

缺点:
1) 继承复用破坏包装,因为继承将超类的实现细节暴露给子类。由于超类的内部细节常常是对于子类透明的,所以这种复用是透明的复用,又称“白箱”复用。

2) 如果超类发生改变,那么子类的实现也不得不发生改变。

3)从超类继承而来的实现是静态的,不可能在运行时间内发生改变,没有足够的灵活性。

4)继承只能在有限的环境中使用。

此部分引用自:http://www.cnblogs.com/temptation/archive/2008/03/10/1098351.html

软件设计原则(七)合成/聚合复用原则(Composite/Aggregate Reuse Principle,CARP)相关推荐

  1. 设计模式七大原则之合成/聚合复用原则(CARP)

    合成/聚合复用原则(CARP) 问题的提出: 如果有类A和类B,类A有方法opertion1(). opertion2() 和 opertion3(),类B需要用类A的方法opertion2() ,如 ...

  2. 07.合成复用原则(Composite/Aggregate Reuse Principle,CARP)

    1.定义 指尽量使用对象 组合(has-a)/聚合(contanis-a),而不是继承关系达到软件复用的目的 继承我们叫做白箱复用,相当于把所有的实现细节暴露给子类.组合/聚合也称之为黑箱复用,对类以 ...

  3. 设计模式六大原则——合成/聚合复用原则(CARP)

    1.定义 简而言之,对于合成/聚合复用原则的定义就是:要尽量使用合成和聚合,尽量不要使用继承. 2.释义 为什么"要尽量使用合成和聚合,尽量不要使用继承"呢? 这是因为: 第一,继 ...

  4. 合成/聚合复用原则(CARP)

    组合/聚合复用原则(Composite/Aggregate Reuse Principle或CARP),就是在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分,新对象通过向这些对象的委派达到 ...

  5. 面向对象设计原则七:组合/聚合复用原则

    组合/聚合复用原则(LSP) 定义:优先使用组合,使系统更灵活,其次才考虑继承,达到复用的目的. 重用的方式: 继承.组合.聚合 解释说明: 继承:在我们想复用代码时,我们一般会优先想到继承,但是具有 ...

  6. 真题详解(数字签名算法)-软件设计(七十八)

    真题详解(有限自动机)-软件设计(七十七)https://blog.csdn.net/ke1ying/article/details/130748759 可用于数字签名算法的是_____. 答案:非对 ...

  7. 面向对象设计原则之6-合成复用原则

    合成复用原则(Composite Reuse Principle or CRP) 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archi ...

  8. 【设计模式】设计原则:CARP 合成复用原则

    合成复用原则(Composite/Aggregate Reuse Principle,CARP)是指尽量使用对象组合(has-a)/聚合(contanis-a),而不是继承关系达到软件复用的目的.可以 ...

  9. 设计原则-迪米特原则与合成复用原则

    迪米特原则(Law of Demeter LoD) 迪米特原则又叫最少知道原则(Least Knowledge Principle,LKP),这里的最少知道主要是强调,调用者对传入的参数,和接受到的返 ...

最新文章

  1. tomcat 连接oracle重连,JSP+Tomcat连接Oracle数据库
  2. 人工智能进阶-CIFAR-10数据集介绍
  3. 神鬼传奇小技巧:教你如何修改自己想要的时装
  4. ActiveMQ与xml rpc
  5. Ueditor富文本添加视频内容,视频不显示以及编辑富文本时,视频不显示解决方案
  6. Pig的安装和简单使用
  7. 光耦的CTR(Current Transfer Ratio)值概念及计算方法
  8. 【转】从零开始学图形学:10分钟看懂贝塞尔曲线
  9. 华为云登顶HotpotQA多跳知识推理问答评测
  10. 使用R语言进行时间序列分析
  11. Python代码混淆工具,Python源代码保密、加密、混淆
  12. 机器学习入门——线性回归预测广告投入数据集
  13. python 基于smb通信协议实现NAS服务器文件上传和下载
  14. 京东热 key 探测框架新版发布JD-hotkey,单机 QPS 可达 35 万
  15. H5页面手机端禁止缩放的正确方式
  16. Linux打开21端口
  17. Python IDLE编写代码 输入反斜杠\显示为人民币符号¥
  18. iOS 给控件View添加角标BadgeValue
  19. 拓嘉辰丰:拼多多差异化运营,做特色店铺
  20. 淘宝旺旺智能回复软件 旺旺智能客服 旺旺聊天机器人

热门文章

  1. 22行代码AC——L1-023 输出GPLT(~解题报告~)
  2. [leetcode]94.二叉树的中序遍历
  3. matlab中的图像类型
  4. HTTP协议长短连接以及无状态
  5. sTC8G1K08+通过串口显示内部电压_基于51单片机的数字电流电压表
  6. Linux PXE批量网络装机与Kickstart 无人值守安装
  7. win service 2003 和 win service2008 区别
  8. c#sort升序还是降序_c# List的sort排序方法详解
  9. vue函数如何调用其他函数?_好程序员Python教程系列之递归函数与匿名函数调用...
  10. 微信支付宝服务器在哪里,支付宝支付与微信支付服务端回调notify_url数据的区别...