里氏替换原则(Liskov Substitution Principle,LSP)是指:继承必须确保超类所拥有的性质在子类中仍然成立。
通俗来讲就是:子类可以扩展父类的功能,但不能改变父类原有的功能。也就是说:子类继承父类时,除添加新的方法完成新增功能外,尽量不要重写父类的方法。
当需要重写父类方法的时候,可以将子类"提升",两个类共同继承更高层的抽象类或接口。两个类的关系由扩展转为关联。下面举例来说明。
Swallow(燕子)是会飞的鸟,而BrownKiwi(几维鸟)是不会飞的鸟。
假如重写BrownKiwi类的setFlySpeed()方法,将飞行速度speed设置为0,那再调用BrownKiwi对象的getFlyTIme则会得到"除0异常"。
想要避免此类问题有很多方法,里氏替换原则提供了一种解决方案,就是将BrownKiwi提升,并让Swallow和BrownKiwi同时继承更高层的一个类。如下图:
这个例子可能不够典型,缺少一些说服力。我觉得设计模式的原则,只是一种方向性的建议,在实际开发活动中,还是要因地制宜,根据实际情况来进行合理的设计。