7.10 其他面向对象设计原则1: 开-闭原则OCP
其他面向对象设计原则1: 开-闭原则OCP
Open-Closed Principle (OCP)
5.1 设计变坏的前兆 Signs of Rotting Design
僵硬性 Rigidity
难以更改代码 code difficult to change
从管理角度,拒绝任何的变化成为一种制度
management reluctance(拒绝) to change anything becomes policy
易碎性 Fragility
即使是小小的改动也会导致级联性的后果的 even small changes can cause cascading effects
代码在意想不到的地方终止 code breaks in unexpected places
固定性 Immobility
代码纠缠在一起根本不可能重用 code is so tangled(纠结) that it's impossible to reuse anything
黏滞性 Viscosity
宁愿重新编写也不愿意修改 much easier to hack(乱砍) than to preserve original design
5.2 设计变坏的原因 Causes of Rotting Design
需求不停地变化 Changing Requirements
这是不可避免的 is inevitable
I. Jacobson, OOSE, 1992说,“所有的系统在其生命周期都在发生变化, 如果拟开发的系统生命期多
于一个版本的话,就必须记住这一点”
All systems change during their life-cycles. This must be borne in mind when
developing systems expected to last longer than the first version"
设计的问题:“依赖管理”失衡
导致高耦合、低内聚
5.3 开闭原则 Open-Closed Principle (OCP)
软件系统在其生命周期都在发生变化
无论是好的设计还是坏的设计,都面临着这个问题 both better designs and poor designs have to
face the changes
但好的设计是稳定的 good designs are stable
开-闭原则
软件系统应当允许功能扩展(即开放性)Software entities should be open for extension,
但是不允许修改原有的代码(即关闭性)but closed for modification (OCP)
遵循开-闭原则的模块符合下列准则
Open for Extension – 可以扩展行为以满足新的需求
CLosed for Modification – 但不允许修改模块的源代码
the source code of the module is not allowed to change
5.5 OCP的启发 Heuristics
修改公有的数据,经常冒着“打开”模块的风险
Changes to public data are always at risk to “open” the module
它们常常会引起涟漪效应,导致许多地方连锁修改
They may have a rippling effect requiring changes at many unexpected locations
很难找全出错的地方并修改,一处修改会导致多处又出问题
Errors can be difficult to completely find and fix. Fixes may cause errors elsewhere
1)定义所有的对象 - 数据为私有的 Make all object-data private
2)不要使用全局变量 No Global Variables!
5.7 小结
OCP解决软件的僵硬性和易碎性 attacks software rigidity and fragility!
When one change causes a cascade of changes
OCP 宣言
我们应当尝试设计永远不需要修改的模块
we should attempt to design modules that never need to be changed
系统行为的扩展只需要增加新的代码,不能修改已有的代码
extend the behavior of the system by adding new code. We do not modify old code
模块不允许修改已有的代码,而这种修改会影响客户端
the module is closed to modification in ways that affect clients
7.10 其他面向对象设计原则1: 开-闭原则OCP的更多相关文章
- 设计原则:开-闭原则(Open-Closed Principle, OCP)
开-闭原则就是软件实体应当对扩展开放,对修改关闭.(Software entities should be open for extension,but closed for modification ...
- 设计原则:开闭原则(OCP)
1.什么是开闭原则 开闭原则的英文是Open Closed Principle,缩写就是OCP.其定义如下: 软件实体(模块.类.方法等)应该"对扩展开放.对修改关闭". 从定义上 ...
- C# 实例解释面向对象编程中的开闭原则
在面向对象编程中,SOLID 是五个设计原则的首字母缩写,旨在使软件设计更易于理解.灵活和可维护.这些原则是由美国软件工程师和讲师罗伯特·C·马丁(Robert Cecil Martin)提出的许多原 ...
- Java设计模式(1:软件架构设计七大原则及开闭原则详解)
前言 在日常工作中,我们使用Java语言进行业务开发的时候,或多或少的都会涉及到设计模式,而运用好设计模式对于我而言,又是一个比较大的难题.为了解决.克服这个难题,笔主特别开了这个博客来记录自己学习的 ...
- js 的七大原则--单一原则、开闭原则、替换原则(一)
一.前言: js 的七大设计原则: 1.单一原则 2.开闭原则 3.里氏替换原则 4.依赖倒转原则 5.接口隔离原则 6.合成复用原则 7.迪米尔法则 二.单一原则 1.定义:单一原则就是一个对象或者 ...
- Java的开发—面向对象的7大原则之开闭原则(一)
开闭原则(Open Close Principle) 一.定义: 软件中的(类.模块.函数等等)应该对于扩展是开放的,对于修改时关闭的.意味着一个实体允许在不改变它的源代码的前提变更它的行为 这里的软 ...
- 最简单直接地理解Java软件设计原则之开闭原则
写在前面 本文属于Java软件设计原则系列文章的其中一篇,后续会继续分享其他的原则.想以最简单的方式,最直观的demo去彻底理解设计原则.文章属于个人整理.也欢迎大家提出不同的想法. 首先是一些理论性 ...
- 深入理解JavaScript系列(7):S.O.L.I.D五大原则之开闭原则OCP
前言 本章我们要讲解的是S.O.L.I.D五大原则JavaScript语言实现的第2篇,开闭原则OCP(The Open/Closed Principle ). 开闭原则的描述是: Software ...
- S.O.L.I.D: PHP 面向对象设计的五个基准原则
S.O.L.I.D 是首个 5 个面向对象设计 (OOD) 准则的首字母缩写,这些准则是由 Robert C. Martin 提出的,他更为人所熟知的名字是 Uncle Bob. 这些准则使得开发出易 ...
随机推荐
- Mysql导入表信息[Err] 1067 - Invalid default value for '字段名'
修改mysql配置文件 vi /etc/my.cnf //添加以下配置 sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISI ...
- 【Java】NO.120.JDK.1.JDK8.1.001-【Java8实战】
Style:Mac Series:Java Since:2018-09-26 End:2018-09-26 Total Hours:1 Degree Of Diffculty:5 Degree Of ...
- 【Python】-NO.97.Note.2.Python -【Python 基本数据类型】
1.0.0 Summary Tittle:[Python]-NO.97.Note.2.Python -[Python 基本数据类型] Style:Python Series:Python Since: ...
- spring-boot 速成(2) devtools之热部署及LiveReload
JRebel热部署插件相信很多人都知道,但是这是一款商业插件,spring-boot框架也提供了类似的功能,即:devtools,关键是免费的! 使用方法如下: 一.添加 devtools依赖 dep ...
- 2018-2019-1 20189203《linux内核原理与分析》第六周作业
第一部分 给Menu OS增加命令 输入命令 rm -rf menu git clone http://github.com/mengning/menu.git make rootfs 查看增加的ti ...
- 58.Less介绍及其与Sass的差异
Less英文官网需要开启VPN才能正常访问,如果你无法打开Less官网,建议您移步到Alexis Sellier领导的团队所译的中文官网Less中文. ——大漠 事实证明,Less——以及Sass对于 ...
- 一个不错的git资源站点
https://backlog.com/git-tutorial/cn/stepup/stepup2_8.html
- noip2016海港
题目描述 Description 小K是一个海港的海关工作人员,每天都有许多船只到达海港,船上通常有很多来自不同国家的乘客. 小K对这些到达海港的船只非常感兴趣,他按照时间记录下了到达海港的每一艘船只 ...
- .Net 多线程 (1) Task
多线程是一种有效提高程序工作效率的方法.当然为了效率需要使用更多的cpu,内存等资源. 并发是两个队列交替使用一台咖啡机,并行是两个队列同时使用两台咖啡机,如果串行,一个队列使用一台咖啡机,那么哪怕前 ...
- npm报错处理
在npm install 命令下载的时候经常会出现下面的报错: 解决办法: npm cache clean --force npm install