标签:
软件设计应该兼顾灵活性与稳定性,提倡外静内动。外静指保持外部的接口不变,内动指允许内部的实现变动。无论是抽象还是设计模式以及库、框架、架构等的设计,无不将此奉为圭臬。
实现继承可能会破坏父类的封装,如访问父类的protected成员、暴露基础类、覆盖父类的方法。
实现继承最大的硬伤是在类族之间建立了强耦合关系,使代码趋于僵硬、脆落和复杂。
子类在覆盖父类某一方法时,不仅要保证该方法的规范,还要维持相应关联方法的规范,不能破坏父类规范之内的逻辑关联。
当祖先类不能在为后代类提供孤立于内部实现的私有接口时,前者的封装便会被破坏,其改动可能会牵连到后者,造成“脆落的基类”问题。
提倡接口继承,慎用实现继承。
非抽象类不适宜作基类。
为继承而设计的类应该做到:禁用protected域成员;保证protected方法成员的规范性和稳定性;防止覆盖的副作用。
非多态方法虽然不如多态方法灵活,但更稳定可靠,不仅能避免继承带来的安全漏洞和封装破坏,还可能带来性能上的改善。
当类的一个公有方法直接或间接调用了自身的另一个多态方法时,应特别谨慎。如果不能杜绝这类自用,那必须将其规范化,以免被子类错误地覆盖。此外,应尽量采用接口非虚原则来分离接口与挂钩: 让该公有方法不是多态的接口,让该多态方法不是公有的挂钩。
类的实例方法一般有4种用途(不排除一法多用):
* 除内部回调外其他最好是非多态的
继承与组合的对比
组合强调整体与部分之间静态结构上的关系,委托转发强调外部接口与内部实现之间动态分离。
标签:
原文地址:http://www.cnblogs.com/guihuo/p/5625419.html