`
conkeyn
  • 浏览: 1530415 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

“开-闭”原则

 
阅读更多

        “开-闭”原则讲的是:一个软件实体应当对扩展开放,对修改关闭。

         英文原文是:Software entities should be open for extension, but closed for modification.
        这个原则说是,在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展。换言之,应当可以在不必修改源代码的情况下改变这个模块的行为。
        这话听上去好像是矛盾的,但是实际上本书将在后面给出的几个面向对象的设计原则和设计模式中很具体的说明如何在设计上做到这一点。
        所有的软件系统都有一个共同的性质,即对它们的需求都会随时间的推移而发生变化。在软件系统面临新的需求时,系统的设计必须时稳定的。满足“开-闭”原则的设计可以给一个软件系统两个无可比拟的优越性:
                1、通过扩展已有的软件系统,可以提供新的行为,以满足对软件的新需求,使变化中的软件系统有一定的适应性和灵活性。
                2、已有的软件模块,特别是最重要的抽象模块不能再修改,这就是使变化中的软件系统有一定的稳定性和延续性。
        具有这两上优点的软件系统是一个在高层次上实现了复用的系统,也是一个易于维护的系统。

        抽象化是关键
        解决问题的关键在于抽象化。在像Java语言这样的面向对象的编程语言里面,可以给系统定义出一个一劳永逸、不再更改的抽象设计,此设计允许有无穷无尽的行为在实现层被实现。在Java语言里,可以给出一个或多个抽象Java类或Java接口,规定出所有的具体类必须提供的方法特征(Signature)作为系统设计的抽象层。这个抽象层预见了所有的可能扩展,因此,在任何扩展情况下都不会改变。这就使得系统的抽象层不需修改,从满足了“开-闭”原则的第二条:对修改关闭。
        同时,由于从抽象层导出一个或多个新的具体类可以改变系统的行为,因此系统的设计对扩展是开放的,这就满足了“开-闭”原则的第一条。
        关于在Java语言中实现抽象化的方法,请阅读后面的“专题:Java接口”一章和“专题:抽象类”一章。
        对可变性的封装原则
        “开-闭”原则如果从另外一角度讲述,就是所谓的“对可变性的封装原则”(Principle of Encapsulation of Variation,常常略写做EVP)。“对可变性的封装原则”讲的是找到一个系统的可变因素,将之封装起来。
        在[GOF95]中说:考虑你的设计中什么可能会发生变化。与通常焦点放到什么会导致设计改变的思考方式正好相反,这一思路考虑的不是什么会导致设计改变,而是考虑你充许什么发生变化而不让这一变化导致重新设计。
        [SHALL01]将这一思想用一句话总结为:“找到一个系统的可变因素,将它封装起来”,并将它命名为“对可变性的封装原则”。
        “对可变性的封装原则”意味着两点:
                1、一种可变性不应当散落在代码的很多角落里,而应当被封装到一个对象里面。同一种可变性的不同表象意味着同一个继承等级结构中的具体子类,因此,读者可以期待在设计模式中看到继承关系。
                继承应当被看做是专卖店装变化的方法,而不应当被认为是从一般的对象生成特殊的对象的方法[SHALL01]。
                2、一种可变性不应当与另一种可变性混合在一起。如果读者留心本书所研究的这些设计模式的类图的话,就会发现所有类图的继承结构一般都不会超过两层,不然就意味着将两种不同的可变性混合在一起了。
        显然,“对可变性的封装原则”从工程的角度讲解了如何实现“开-闭”原则。如果能够将“对可变性的封装原则”作为总的设计原则的话,那么按照这个原则进行的系统设计,应当遵守“开-闭”原则。
        尽管在很多情况下,无法百分之百地做到“开-闭”原则,但是如果向这个方向上的努力能够得到部份的成功,也可以显著地改善一个系统的结构。

分享到:
评论

相关推荐

    JAVA设计模式之设计原则 ---开闭原则源码

    开闭原则是面向对象设计中的一个核心原则,它在JAVA设计模式中占据着重要的地位。这一原则由格里·贝斯提出,旨在指导开发者如何设计可维护和可扩展的软件系统。开闭原则(Open-Closed Principle,OCP)的核心思想是...

    开闭原则----图片缓存

    开闭原则是面向对象设计中的一个基本原则,它由软件工程专家 Bertrand Meyer 在其著作《Object-Oriented Software Construction》中提出。这个原则的核心思想是“对扩展开放,对修改关闭”。简单来说,就是模块应该...

    JAVA开闭原则

    JAVA开闭原则是一种重要的软件设计思想,其核心理念在于提高软件系统的灵活性、稳定性和可维护性。开闭原则强调“对扩展开放,对修改关闭”,即在设计阶段应该确保软件模块能够在不修改原有代码的基础上,通过扩展的...

    什么是开闭原则,java开闭原则

    开闭原则是面向对象设计的核心原则之一,它的全称是"对扩展开放,对修改关闭",即在软件设计过程中,我们希望系统能够容易地添加新功能,同时保持原有代码的稳定性,避免频繁修改。这一原则由 Bertrand Meyer 在他的...

    OOD设计基本原则整理.doc

    OOD 设计基本原则之一:开-闭原则 开-闭原则是 OOD 设计的核心原则之一,该原则强调一个软件实体应当对扩展开放,对修改关闭。也就是说,在设计一个软件实体的时候,应当使这个软件实体可以在不修改或少修改的前提...

    java设计模式五大原则.doc

    Java 设计模式五大原则是软件设计中非常重要的原则,它们是:开-闭原则、里氏代换原则、依赖倒转原则、接口隔离原则和迪米特法则。这些原则都是软件设计的基石,它们指导我们如何设计出更加灵活、可维护、可扩展的...

    面向对象的设计原则

    - **可插入性**:同样地,开-闭原则、里氏替换原则、依赖倒置原则和合成/聚合复用原则也有助于提高系统的可插入性。 通过这些原则的综合运用,可以帮助开发团队构建出更加健壮、灵活且易于维护的软件系统。

    程序设计的七大原则

    #### 一、开-闭原则 (Open-Closed Principle, OCP) 开-闭原则是面向对象设计中最基本的原则之一,它强调软件实体应该对扩展开放,对修改关闭。这意味着在设计一个模块时,应该能够让它在不被修改的前提下被扩展,即...

    面型对象设计原则——开闭原则(OCP)的Demo+静态结构图

    开闭原则(Open-Closed Principle,简称OCP)是面向对象设计中的一个核心原则,它在软件工程领域具有举足轻重的地位。该原则由 Bertrand Meyer 在其著作《Object-Oriented Software Construction》中提出,旨在提高...

    SQL语句优化2

    开-闭原则(OCP):一个软件实体应当对扩展开放,对修改关闭。 里氏代换原则(LSP):一个软件实体如果使用的是一个基类的话,那么一定适用于其子类。 依赖倒转原则(DIP):要依赖于抽象,不要依赖于具体。 接口隔离...

    java编程模式集合(上)

    - **缺点**:由于工厂类包含了所有产品的创建逻辑,当添加新产品时,需要修改工厂类,违反了“开-闭原则”。 2. **工厂方法模式**: - **定义**:工厂方法模式将产品创建的职责交给了子类,每个子类都有一个与之...

    软件设计的七大原则.doc

    软件设计的七大原则是软件设计的精髓所在,这七大原则分别是开闭原则、里氏代换原则、依赖倒置原则、接口隔离原则、合成/聚合复用原则、迪米特法则和抽象类原则。 一、 开闭原则(OCP) 开闭原则是指一个软件实体...

    开闭原则1

    开闭原则是面向对象设计的基本原则之一,由勃兰特·梅耶在1988年提出。这个原则的核心思想是:软件实体(如模块、类、接口和方法)应该对扩展开放,对修改关闭。这意味着在需求变更时,我们可以通过增加新代码来扩展...

    设计模式6大原则:开闭原则

    设计模式6大原则:开闭原则

    软件设计的七大原则

    这些原则包括开闭原则、里氏代换原则、依赖倒置原则、接口隔离原则、合成/聚合复用原则、迪米特法则和抽象类原则。这些原则的目的是为了提高软件系统的灵活性、适应性、稳定性和延续性。 一、 开闭原则(OCP) 开...

    java与模式

    4:开-闭 原则;5:java语言接口;6:抽象类;7:里氏代换原则;8:依懒倒转原则;9:接口隔离原则;10:合成/聚合复用原则;11:迪米特法原则;12:简单工厂模式;13:工厂方法模式;14:抽象工厂模式;15:单例模式;16:单例模式与MX记录...

    Java设计模式笔记

    2. **开-闭原则**: - 这个原则指出,软件实体(如类、模块或函数)应允许扩展,但禁止修改。这意味着当我们需要改变功能时,我们应该通过添加新代码而非修改现有代码来实现。这提高了软件的可维护性和可扩展性。 ...

Global site tag (gtag.js) - Google Analytics