官术网_书友最值得收藏!

  • Expert Android Programming
  • Prajyot Mainkar
  • 319字
  • 2021-07-08 10:29:14

Liskov Substitution Principle

The Liskov Substitution Principle states that:

Child classes should never break the parent class' type definitions.

According to this principle, a subclass should override the parent class's methods in a way that does not break functionality from a client's point of view.

According to this principle, if a class is extending another class, the functionality of the child class should not conflict with that of its parent.

We can demonstrate this with the following example:

public class Rectangle { 
   private double length; 
   private double height; 
 
 
   public void setLength(double length) { 
       this.length = length; 
   } 
 
   public void setHeight(double height) { 
       this.height = height; 
   } 
 
   public double getLength() { 
       return length; 
   } 
 
   @Override 
   public double getHeight() { 
       return height; 
   } 
 
   public double getArea() { 
       return (length * height); 
   } 
} 

Here we have a rectangle. As we know, a square is also a type of rectangle, so it can extend the Rectangle class. Also we know that the height and the width of the square have to be the same so the getter can be written like this:

public class Square extends Rectangle { 
 
   @Override 
   public void setHeight(double height) { 
       this.length = height; 
       this.height = height; 
   } 
 
   @Override 
   public void setLength(double length) { 
       this.length = length; 
       this.height = length; 
   } 
} 

As can be seen from the preceding definition, we can get a rectangle also from the square implementation.

So now let's get an instance of Rectangle from the Square class:

Rectangle r = new Square(); 
r.setHeight(5); 
r.setLength(10); 

Now if we try to get the area, we will get 100 instead of 50, as a square has both the same length and height, which is not the case with a rectangle, and this violates the Liskov Substitution Principle.

A simple example of the Liskov Substitution Principle would be a List and ArrayList. An ArrayList implements a List but it does not change the basic functionality of the List.

主站蜘蛛池模板: 拜城县| 英吉沙县| 和顺县| 安溪县| 沁阳市| 平潭县| 揭东县| 米易县| 田东县| 双流县| 山东省| 资溪县| 岳阳县| 贵溪市| 诸暨市| 南京市| 化德县| 拉孜县| 商丘市| 青河县| 襄汾县| 西畴县| 包头市| 乐至县| 九台市| 丹巴县| 普陀区| 琼海市| 景宁| 永兴县| 榆社县| 沭阳县| 马关县| 绥阳县| 南皮县| 临高县| 新丰县| 宝兴县| 湟源县| 图片| 大宁县|