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

Posted 庸人、自扰

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了冒号课堂阅读笔记OO的继承相关的知识,希望对你有一定的参考价值。

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

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

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

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

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

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

非抽象类不适宜作基类。

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

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

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

 

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

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

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

 

继承与组合的对比

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

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

以上是关于冒号课堂阅读笔记OO的继承的主要内容,如果未能解决你的问题,请参考以下文章

冒号课堂阅读笔记编程范式整理

课堂笔记--初识继承和多态 继承

《面向对象与程序设计》阅读笔记1

我的《冒号课堂》学习笔记设计原则间接原则

我的《冒号课堂》学习笔记设计原则依赖原则

我的《冒号课堂》学习笔记设计原则内聚原则