`
student_lp
  • 浏览: 432030 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

编程模式---“开--闭”原则(OCP)

阅读更多

      经典力学的基石是牛顿三大定律。而面向对象的可复用设计(OOD)的第一块基石,便是“开--闭”原则(Open-Closed principle,缩写为OCP)。

一、什么是“开闭”原则?

      “开--闭”原则讲的是:一个软件实体应当对扩展开放,对修改关闭。英文的原文是:Software entities should be open for extension,but closed for modification。

      这个原则说的是,在设计一个模块的时候,应当使这个模块可以在不修改的前提下被扩展。换言之,应当可以在不必修改源代码的情况下修改这个模块的行为。这句话听上去好像是矛盾的,但是实际上通过面向对象的设计原则和设计模式就能实现这一点。

    所有的软件系统都有一个共同的性质,即对他们的需求都会随时间的推移而发生变化。在软件系统面临新的需求时,系统的设计必须是稳定的。满足“开--闭”原则的设计可以给一个软件系统两个无可比拟的优越性:

    ①通过扩展已有的软件系统,可以提供新的行为,以满足对软件的新需求,使变化中的软件系统有一定的适应性和灵活性。②已有的软件模块,特别是最重要的抽象层模块不能在修改,这就使变化中的软件系统有一定的稳定性和延续性。

   具有这两个优点的软件系统是一个在高层次上实现了复用的系统,也是一个易于维护的系统。

二、怎样做到“开--闭”原则?

    “知固而不知革,物失其则;知革而不知固,物失其均。”如果一个系统不可扩展,则系统失去其价值;而一个系统动辄需要修改,便会失去重心。

     解决“开闭”原则的关键在于抽象化。在像java语言这样的面向对象的编程语言里面,可以给系统定义出一个一劳永逸、不在更改的抽象设计,此设计允许有无穷无尽的行为在实现层被实现。在java语言里,可以给出一个或多个抽象java类或java接口,规定出所有的具体类必须提供的方法的特征作为系统设计的抽象层。这个抽象层预见了所有可能扩展,因此,在任何情况下都不会改变。这就使的系统的抽象层不需要修改,从而满足了“开闭”原则的第二条:对修改关闭。

     同时,由于从抽象层导出一个或多个新的具体类可以改变系统的行为,因此系统的设计对扩展是开发的,,这就满足了“开闭”原则的第一条:对扩展开放。

三、对可变性的封装原则

      “开闭”原则如果从工程的角度来讲,就是所谓的“对可变性的封装原则”。“对可变性的封装原则”讲的是找到一个系统的可变因素,将之封装起来。在这里意味着两点:

    ①一种可变性不应当散落在代码的很多角落里,而应当被封装到一个对象里面。同一种可变性的不同表象意味着同一个继承等级结构中的具体子类,因此,可以在设计模式中看到继承关系。继承应该被当做是封装变化的方法,而不应当被认为是从一般的对象生成特殊的对象的方法。

    ②一种可变性不应当与另一种可变性混合在一起。如果深入研究设计模式的类图的话,会发现所有的类图的继承结构一般都不会超过两层,不然意味着将两种不同的可变性混合在一起了。

    如果将“可变性的封装原则”作为总的设计原则的话,按照这个原则进行的系统设计就应当遵守“开闭”原则。尽管在很多情况下,无法百分之百的做到,但是如果向这个方向上努力就能够得到部分的成功,就可以显著改善一个系统的结构。

四、开闭原则与其他设计原则的关系

       做到开闭原则不是一件容易的事情,但是她也是有很多规律可循的。这些规律也同样以设计原则的身份出现,但是他们都是“开闭”原则的手段和工具,是附属于“开闭”原则的。这些设计模式包括:里氏代换原则、依赖倒转原则、合成/聚合复用原则、迪米特法则、接口隔离原则。

 

 本文通过总结《java与模式》而来。

分享到:
评论

相关推荐

    该怎么使用Java设计模式编程中的OCP开闭原则?.pdf

    该怎么使用 Java 设计模式编程中的 OCP 开闭原则? 在软件开发中,开闭原则是面向对象设计中最基础的设计原则之一,它指导我们如何建立稳定灵活的系统。开闭原则定义:一个软件实体如类、模块和函数应该对扩展开放...

    该怎么使用Java设计模式编程中的OCP开闭原则?.docx

    Java 设计模式中的 OCP 开闭原则 在软件设计中,OCP 开闭原则是其中一个非常重要的设计原则。该原则定义了一个软件实体,如类、模块和函数应该对扩展开放,对修改关闭。也就是说,当软件需要变化时,应该尽量通过...

    23种 设计模式---面向对象的基本原则

    在面向对象编程中,设计模式基于一些基本原则,这些原则构成了良好设计的基础。本篇将深入探讨23种设计模式以及面向对象的基本原则。 面向对象的基本原则主要包括: 1. 单一职责原则(Single Responsibility ...

    实例讲解Java设计模式编程中的OCP开闭原则

    开闭原则(Open-Closed Principle,简称OCP)是面向对象设计的核心原则之一,由艾兹格·迪米特里斯·迪米特里亚迪斯(Erich Gamma)提出。它的核心思想是“软件实体(如类、模块和函数)应当对扩展开放,对修改关闭...

    《设计模式--基于C#的工程化实现及扩展》.(王翔).rar.rar

    此外,书中可能还会涉及面向对象设计原则,如单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、依赖倒置原则(DIP)和接口隔离原则(ISP),这些都是设计模式背后的重要理论基础。 总的来说,《设计模式--基于C#...

    Java语言编程规范--华为技术有限公司

    - 遵循开放封闭原则(OCP),类应可扩展,但不可修改。 - 方法参数数量应尽量少,避免过多参数导致调用复杂。 8. **并发编程** - 使用同步机制确保线程安全,如 `synchronized` 关键字或 `java.util.concurrent`...

    设计模式-王翔 全本

    除了介绍各个模式,王翔还会讨论设计原则,如单一职责原则(Single Responsibility Principle, SRP)、开闭原则(Open-Closed Principle, OCP)和依赖倒置原则(Dependency Inversion Principle, DIP)。这些原则是...

    java并发编程:设计原则与模式.rar

    面向对象的设计原则,如单一职责原则(SRP)、开放封闭原则(OCP)、里氏替换原则(LSP)、依赖倒置原则(DIP)和接口隔离原则(ISP),同样适用于并发编程。遵循这些原则可以使代码更加模块化,更易于维护和扩展,...

    2计模式-课程内容.rar

    2. **设计原则**:课程可能会详细讲解SOLID原则,包括单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、接口隔离原则(ISP)和依赖倒置原则(DIP)。这些原则是指导良好面向对象设计的基础。 3. **创建...

    开闭原则1

    开闭原则(Open-Closed Principle,简称OCP)是面向对象设计中的一个核心原则,它由Bertrand Meyer在1988年提出,并被收录在SOLID(单一职责原则、开闭原则、里氏替换原则、接口隔离原则、依赖倒置原则)这五大设计...

    Java软件设计模式[最详尽=面向对象+编程原则+设计模式].rar

    - **SOLID原则**:单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、接口隔离原则(ISP)、依赖倒置原则(DIP)。 - **DRY(Don't Repeat Yourself)**:避免重复代码,提倡模块化和抽象化。 - **...

    03丨面向对象、设计原则、设计模式、编程规范、重构,这五者有何关系?1

    例如,SOLID原则包括单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、接口隔离原则(ISP)和依赖倒置原则(DIP)。设计原则帮助我们避免常见的设计错误,提高代码的灵活性和可维护性。 设计模式是针对...

    设计模式之开放封闭原则

    在C#编程中,设计模式的应用能够提高代码的可读性、可维护性和扩展性。本文将深入探讨“开放封闭原则”这一核心设计原则,并结合C#语言环境进行解析。 开放封闭原则(Open-Closed Principle,OCP)由Bertrand Meyer...

    程序员考试刷题-java8-ocp-study-notes:跟踪OCPJava8书籍学习指南的存储库

    程序员考试刷题java8-ocp-study-notes 跟踪 OCP Java 8 书籍学习指南的存储库 我将在这里介绍的这本书是 Java 8 认证指南的第二部分。 第一个指南涵盖 OCA 考试(我已经通过了),本指南涵盖了 OCP 考试(1Z0-809 ...

    《深入浅出设计模式》读书笔记--策略模式与三个设计原则

    2. **开闭原则 (Open-Closed Principle, OCP)**: 类应该是对扩展开放的,对修改关闭的。策略模式很好地体现了这一点,因为当需要添加新的策略时,无需修改已有的策略类或客户端代码,只需创建一个新的策略类并实现...

    C#面向对象设计模式纵横谈-0.面向对象设计模式与原则

    2. **面向对象设计原则**:包括单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、依赖倒置原则(DIP)和接口隔离原则(ISP)。这些原则是良好面向对象设计的基础,有助于提升代码的可读性、可维护性和可扩展性。 ...

    swift-面向对象设计的设计原则和设计模式

    面向对象设计的原则主要有四个:单一职责原则(Single Responsibility Principle, SRP)、开闭原则(Open-Closed Principle, OCP)、里氏替换原则(Liskov Substitution Principle, LSP)和依赖倒置原则(Dependency...

    NET应用架构设计原则模式与实践源码

    - **开闭原则(OCP)**:软件实体应对扩展开放,对修改关闭,意味着添加新功能时不应修改已有代码。 - **里氏替换原则(LSP)**:子类型必须能够替换它们的基类型,而不影响程序的正确性。 - **依赖倒置原则(DIP...

    设计模式!~可复用软件设计!~

    通过学习和理解这些模式,开发者可以更好地理解和应用面向对象设计原则,如单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、接口隔离原则(ISP)和依赖倒置原则(DIP)。这五项原则是面向对象设计的...

    Csharp设计模式电子版--一本很好C#设计模式

    通过学习《C#设计模式》,读者可以深入理解面向对象设计的原则,如单一职责原则(SRP)、开闭原则(OCP)、里氏替换原则(LSP)、接口隔离原则(ISP)和依赖倒置原则(DIP),并能在实际项目中灵活运用。 总的来说...

Global site tag (gtag.js) - Google Analytics