里氏替换原则
概念定义
里氏代换原则(Liskov Substitution Principle):所有引用基类的地方必须能透明地使用其子类的对象。
问题来源
有一功能P1,由类A完成。现需要将功能P1进行扩展,扩展后的功能为P,其中P由原有功能P1与新功能P2组成。新功能P由类A的子类B来完成,则子类B在完成新功能P2的同时,有可能会导致原有功能P1发生故障。
解决方案
当使用继承时,遵循里氏替换原则。类B继承类A时,除添加新的方法完成新增功能P2外,尽量不要重写父类A的方法,也尽量不要重载父类A的方法。里氏替换原则通俗的来讲就是:子类可以扩展父类的功能,但不能改变父类原有的功能。
实例
package com.morris.pattern.lsp;
public class Rectangle {
protected int width;
protected int height;
public Rectangle(int width,int height) {
this.width = width;
this.height = height;
}
public int calcArea() {
return width * height;
}
}
package com.morris.pattern.lsp;
public class Square extends Rectangle {
public Square(int width,int height) {
super(width,height);
}
@Override
public int calcArea() {
return width * width;
}
}
package com.morris.pattern.lsp;
public class App {
public static void main(String[] args) {
Rectangle rectangle = new Rectangle(10,20);
//Rectangle rectangle = new Square(10,20);
System.out.println(rectangle.calcArea());
}
}
如果把长方形类Rectangle替换为正方形类Square,那么求出的面积就不正确了,原因是继承的时候重写了父类的getArea方法。这是违背里氏替换原则的。
总结
继承给程序设计带来巨大便利的同时,也带来了弊端。如果一个类被其他的类所继承,则当这个类需要修改时,必须考虑到所有的子类,并且父类修改后,所有涉及到子类的功能都有可能会产生BUG。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。