oop - 开闭原则与多态性

开放/封闭原则指出软件实体(类、模块等)应该对扩展开放,但对修改关闭。我今天了解到这个,我的老师说这个概念与多态性的概念有着内在的联系。我真的看不出这两个概念是如何联系在一起的,有人能解释一下吗?

最佳答案

这是我的解释。 看下面的例子:

public interface IShape
{
    void Draw();
}

public class Square : IShape
{
    public void Draw()
    {
        // DRAW SQUARE
    }
}

public class Circle : IShape
{
    public void Draw()
    {
        // DRAW CIRCLE
    }
}

public class Renderer
{
    public void DrawShapes(ICollection<IShape> shapes)
    {
        foreach (var shape in shapes)
        {
            shape.Draw();
        }
    }
}

此代码对扩展开放,对修改关闭,因此它遵循 OCP 原则。为什么?如果您需要使应用程序能够绘制新形状(例如三角形),则无需修改 Render 类的 DrawShapes 方法。
您只需要创建一个实现接口(interface) IShape 的新类“Triangle”,并将其传递给 DrawShapes 方法即可。
此代码也是多态的,因为“DrawShapes”方法不需要知道它正在呈现的形状的类型。

注意一件事:O.C.P.的关闭。原则永远是战略性的。这是什么意思?这意味着您不能让代码 100% 禁止修改。示例:如果您需要在圆圈之前绘制所有正方形,会发生什么情况?在这种情况下,您必须修改 DrawShapes 方法;也许使用策略模式,您可以注入(inject)策略来对形状的绘制进行排序。

https://stackoverflow.com/questions/40754311/

相关文章:

laravel - 在 Laravel 5 中间件中获取 cookie

batch-file - "nircmd.exe monitor on"不工作

css - 从 Chrome 开发者工具样式更改输入占位符颜色

python - 如何在发布数据python中接收字典

macos - ld 链接器错误 - 体系结构 x86_64 的 undefined symbol

python-3.x - 如何为 ttk.OptionMenu 编辑 ttk 样式

scala - 没有参数的scala方法中的模式匹配

haskell - 如何将整数插入排序列表

R - 在没有分配的情况下构建具有多列的数据框

r - 函数不能 "see"全局环境中定义的其他函数