开放封闭原则(OCP,Open Closed Principle)

开放封闭原则是所有面向对象原则的核心。

软件设计本身所追求的目标就是封装变化、降低耦合,而开放封闭原则正是对这一目标的最直接体现。

其他的设计原则,很多时候是为实现这一目标服务的,例如以里氏替换原则实现最佳的、正确的继承层次,就能保证不会违反开放封闭原则。

关于开放封闭原则,其核心的思想是:

软件实体应该是可扩展,而不可修改的。也就是说,对扩展是开放的,而对修改是封闭的。

因此,开放封闭原则主要体现在两个方面:

对扩展开放,意味着有新的需求或变化时,可以对现有代码进行扩展,以适应新的情况。

对修改封闭,意味着类一旦设计完成,就可以独立完成其工作,而不要对类进行任何修改。

相信工作过一段时间的程序员都明白 “需求总是变化”、“世界上没有一个软件是不变的”,这些言论是对软件需求最经典的表白。

从中透射出一个关键的意思就是,对于软件设计者来说,必须在不需要对原有的系统进行修改的情况下,实现灵活的系统扩展。而如何能做到这一点呢?

只有依赖于抽象。实现开放封闭的核心思想就是对抽象编程,而不对具体编程,因为抽象相对稳定。

让类依赖于固定的抽象,所以对修改就是封闭的;

而通过面向对象的继承和对多态机制,可以实现对抽象体的继承,通过覆写其方法来改变固有行为,实现新的扩展方法,所以对于扩展就是开放的。

这是实施开放封闭原则的基本思路,

同时这种机制是建立在两个基本的设计原则的基础上,这就是里氏替换原则和合成/聚合复用原则。

对于违反这一原则的类,必须进行重构来改善,常用于实现的设计模式主要有 Template Method (模板方法)模式和 Strategy (策略)模式。

而封装变化,是实现这一原则的重要手段,将经常发生变化的状态封装为一个类。

个人理解 OCP 的思想其实就是说 要依赖于“接口”,这个接口指的不是C#中的那个接口(当然也是)

OCP 的思想应用其实可以很广泛,比如系统与系统,模块与模块,像这类就比如 微服务 使用 http/rpc 等协议 我们定义“接口” 来进行各种信息交互。

如果是类与类之间的交互 那当然就是 interface 了。

最新文章

  1. C++服务器设计(七):聊天系统服务端实现
  2. wemall app商城源码中实现带图片和checkbox的listview
  3. ReactiveSwift源码解析(七) Signal的CombineLatest的代码实现
  4. 解决跨站脚本注入,跨站伪造用户请求,sql注入等http安全漏洞
  5. [python]global与nonlocal关键字
  6. yield的理解
  7. lodash用法系列(4),使用Map/Reduce转换
  8. [Linux实用工具]Linux监控工具munin的展示(Nginx)
  9. POJ 3258 River Hopscotch(二分答案)
  10. 1、rbac权限组件-初识, 中间件校验1
  11. RabbitMQ(二):mandatory标志的作用
  12. cocos代码研究(9)ProgressTimer类学习笔记
  13. 初识 es6之 const
  14. 用JIRA管理你的项目
  15. 打印十字图 queue 搞定
  16. APP移动端开发html模板
  17. code1154 能量项链
  18. canvas操作图片,进行面板画图,旋转等
  19. Docker-安装与部署
  20. 智能合约安全事故回顾(3)-DOS漏洞导致的KotET事件

热门文章

  1. Python练习-不知道弄个什么鬼
  2. 假·最大子段和 (sdutoj 4359 首尾相连)(思维)
  3. UNIX网络编程 第5章 TCP客户/服务器程序示例
  4. Redis简介——(一)
  5. java 面试题总结(一)
  6. linux 进程内存解析【转】
  7. CSV 中添加逗号
  8. git本地分支和远程分支改名
  9. if(a==1) & if(1==a) 区别
  10. 洛谷P2886牛继电器