软件可维护性:当软件的需求有所改变时,需要进行软件维护,修复错误,改善性能。包括纠错性维护、适应性维护(在不同环境下均可用)、完善性维护(扩充软件的性能,升级)和预防性维护(为了以后的维护方便,对软件的架构进行修整)。软件维护不仅仅是运维工程师的工作,而是从设计和开发阶段就开始了。
可维护性的度量:
(可扩展性,灵活性,可适应性,可管理性,支持性)
- 圈复杂度:衡量代码的结构复杂度。例如,白盒测试时,对代码的每一条路径都进行一次测试,那测试路径的上界即为圈复杂度。
- 代码行数
- 可维护性指数
- 继承的的层次数,类之间的耦合度,单元测试的覆盖度。
模块化设计和模块化原则:
模块化的特点:高内聚,低耦合,信息隐藏,分离关注点。
- 评估模块化的准则:
可分解性、可组合性、可理解性、可持续性(发生变化时受影响范围最小)、出现异常之后的保护(出现异常后受影响范围最小)。 - 模块化设计的规则:
直接映射(能够直接使用的模块),尽量少的接口,尽量小的接口,显示接口,信息隐藏。 - 耦合: 类与类之间的关系,关系越复杂,耦合度越高,设计程序时,尽可能使耦合度较低。
内聚:模块内部的的功能和职责高度相关,则为高内聚。
即低耦合,高内聚。