码迷,mamicode.com
首页 > 其他好文 > 详细

【冒号课堂】【阅读笔记】OO的继承

时间:2016-06-29 01:03:57      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:

软件设计应该兼顾灵活性与稳定性,提倡外静内动。外静指保持外部的接口不变,内动指允许内部的实现变动。无论是抽象还是设计模式以及库、框架、架构等的设计,无不将此奉为圭臬。

实现继承可能会破坏父类的封装,如访问父类的protected成员、暴露基础类、覆盖父类的方法。

实现继承最大的硬伤是在类族之间建立了强耦合关系,使代码趋于僵硬、脆落和复杂。

子类在覆盖父类某一方法时,不仅要保证该方法的规范,还要维持相应关联方法的规范,不能破坏父类规范之内的逻辑关联。

当祖先类不能在为后代类提供孤立于内部实现的私有接口时,前者的封装便会被破坏,其改动可能会牵连到后者,造成“脆落的基类”问题。

提倡接口继承,慎用实现继承。

非抽象类不适宜作基类。

为继承而设计的类应该做到:禁用protected域成员;保证protected方法成员的规范性和稳定性;防止覆盖的副作用。

非多态方法虽然不如多态方法灵活,但更稳定可靠,不仅能避免继承带来的安全漏洞和封装破坏,还可能带来性能上的改善。

当类的一个公有方法直接或间接调用了自身的另一个多态方法时,应特别谨慎。如果不能杜绝这类自用,那必须将其规范化,以免被子类错误地覆盖。此外,应尽量采用接口非虚原则来分离接口与挂钩: 让该公有方法不是多态的接口,让该多态方法不是公有的挂钩。

 

类的实例方法一般有4种用途(不排除一法多用):

  1. 为外界提供服务的公开接口
  2. 为子类提供展开点的内部回调
  3. 为子类或包提供服务的内部接口
  4. 为自身提供服务的私有接口

* 除内部回调外其他最好是非多态的

 

继承与组合的对比

  1. 继承是一种静态显性的关系,而组合是一种动态隐性的关系。
  2. 实现继承是灰盒复用,而组合是黑盒复用。
  3. 多重继承通常不被支持或不被提倡,而多重组合则不然。
  4. 继承是对基础类的兼收并蓄,而组合是对基础类的批判继承。

组合强调整体与部分之间静态结构上的关系,委托转发强调外部接口与内部实现之间动态分离。

【冒号课堂】【阅读笔记】OO的继承

标签:

原文地址:http://www.cnblogs.com/guihuo/p/5625419.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!