开放封闭原则 C.
在这里,我们尝试使用代码库来解释 OCP。首先,我们将展示违反 OCP 的方案,然后我们将删除该违规。
面积计算(OCP 违规代码):
placeholderCopypublic class Rectangle{
public double Width {get; set;}
public double Height {get; set;}
}
public class Circle{
public double Radious {get; set;}
}
public double getArea (object[] shapes){
double totalArea = 0;
foreach(var shape in shapes){
if(shape is Rectangle){
Rectangle rectangle = (Rectangle)shape;
totalArea += rectangle.Width * rectangle.Height;
}
else{
Circle circle = (Circle)shape;
totalArea += circle.Radious * circle.Radious * Math.PI;
}
}
}
现在,如果我们需要计算另一种类型的对象(比如,Trapezium),那么我们就要添加另一个条件。但是从 OCP 规则我们知道应该关闭软件实体进行修改。所以它违反了 OCP。
好。让我们尝试解决实施 OCP 的这种违规行为。
placeholderCopypublic abstract class shape{
public abstract double Area();
}
public class Rectangle : shape{
public double Width {get; set;}
public double Height {get; set;}
public override double Area(){
return Width * Height;
}
}
public class Circle : shape{
public double Radious {get; set;}
public override double Area(){
return Radious * Radious * Math.PI;
}
}
public double getArea (shape[] shapes){
double totalArea = 0;
foreach(var shape in shapes){
totalArea += shape.Area();
}
return totalArea;
}
现在如果我们需要计算另一种类型的对象,我们不需要改变逻辑(在 getArea()
中),我们只需要添加另一个类,如 Rectangle 或 Circle 。