01-开闭原则
目录
在软件开发中,为了提高软件系统的可维护性
和可复用性
,增加软件的可扩展性
和灵活性
,开发要尽量根据 7 条原则来开发程序,从而提高软件开发效率、节约软件开发成本和维护成本。
7条设计原则
以下 7 种设计原则是软件设计模式必须尽量遵循的原则,各种原则要求的侧重点不同。
- 开闭原则是总纲,它告诉我们要对扩展开放,对修改关闭;
- 里氏替换原则告诉我们不要破坏继承体系;
- 依赖倒置原则告诉我们要面向接口编程;
- 单一职责原则告诉我们实现类要职责单一;
- 接口隔离原则告诉我们在设计接口的时候要精简单一;
- 迪米特法则告诉我们要降低耦合度;
- 合成复用原则告诉我们要优先使用组合或者聚合关系复用,少用继承关系复用。
开闭原则定义
开闭原则由勃兰特·梅耶提出,他在 1988 年的著作《面向对象软件构造》中提出:软件实体应当对扩展开放
,对修改关闭
。
Software entities should be open for extension,but closed for modification)
这就是开闭原则的经典定义。
这里的软件实体包括以下几个部分:
- 模块
- 类与接口
- 方法
开闭原则的含义是:当需求改变时,在不修改软件实体的源代码或者二进制代码的前提下,可以扩展模块的功能,使其满足新的需求。
开闭原则的作用
开闭原则是面向对象程序设计的终极目标,它使软件实体拥有一定的适应性和灵活性的同时具备稳定性和延续性。具体来说,其作用如下。
对软件测试的影响
软件遵守开闭原则的话,软件测试时只需要对扩展的代码进行测试就可以了,因为原有的测试代码仍然能够正常运行。
可以提高代码的可复用性
粒度越小,被复用的可能性就越大;在面向对象的程序设计中,根据原子和抽象编程可以提高代码的可复用性。
可以提高软件的可维护性
遵守开闭原则的软件,其稳定性高和延续性强,从而易于扩展和维护。
开闭原则的实现方法
可以通过“抽象约束
、封装变化
”来实现开闭原则,即通过接口或者抽象类为软件实体定义一个相对稳定的抽象层,而将相同的可变因素封装在相同的具体实现类中。
因为抽象灵活性好,适应性广,只要抽象的合理,可以基本保持软件架构的稳定。而软件中易变的细节可以从抽象派生来的实现类来进行扩展,当软件需要发生变化时,只需要根据需求重新派生一个实现类来扩展就可以了。
小结
开闭原则:对扩展开放,对修改关闭。提高可维护性、可复用性、灵活性、可扩展性。
参考
这篇文章写的很不错: 「设计模式」理解面向对象的七大设计原则,消除代码中的坏味道 - 掘金
本文部分收藏来自互联网,仅用于学习研究,著作权归原作者所有,如有侵权请联系删除
markdown 9ong@TsingChan