里氏替换原则
Liskov Substitution Principle 简称LSP。
什么是里氏替换原则
1.如果对每一个类型为S的对象o1,都有类型为T的对象o2,使得以T定义的所有程序P在所有的对象o1都代换成o2时,程序P的行为没有发生变化,那么类型S是类型T的子类型。
2.所有引用基类的地方必须能透明地使用其子类的对象。
简单来说就是子类必须可以替换它的父类
里氏替换原则的优点
- 代码共享,减少创建类的工作量,每个子类都拥有父类的方法和属性;
- 提高代码的重用性;
- 子类可以形似父类,但又异于父类。
- 提高代码的可扩展性。
- 提高产品或项目的开放性。
里氏替换原则的缺点
- 继承是侵入性的。只要继承,就必须拥有父类的所有属性和方法;
- 降低代码的灵活性。子类必须拥有父类的属性和方法。
- 增强了耦合性。当父类的常量、变量和方法被修改时,需要考虑子类的修改,可能导致大段的代码需要重构。
如何做到里氏替换原则
- 子类必须完全实现父类的方法。
对于父类的所有抽象方法,子类必须去完全实现。如果父类的某些方法在子类中已经发生畸变,应该断开父子继承关系,转而采用依赖、聚集、组合等关系来代替。 - 子类可以有自己的个性
子类可以实现自己独有的方法。 - 覆盖或实现父类的方法时输入参数可以被放大
为了保证子类可以替换父类,比如父类可以接受0-10,而子类只接受0-5,那么当子类替换父类时就会出现问题,所以子类输入参数可以放大不能缩小。 - 覆写或实现父类的方法时输出结果可以被缩小
为了保证子类可以替换父类,比如父类返回0-5,而子类返回0-10,那么当子类替换父类的时候后续操作就可能出现问题,所以子类输出结果可以缩小不能放大。
代码举例
感觉里氏替换原则不是很适用于javascript编程。