前段日子参加了公司组织的《软件的耦合度》培训,该培训主要介绍了软件耦合的定义,耦合的分类,每种耦合存在的必要性、优缺点及修改建议等内容,现将其培训的主要内容以及注意事项总结归纳一下,并在此分享给软件爱好者。
一、软件耦合的定义
软件耦合即是不同模块软件之间的联系复杂程度。说的通俗一点,软件的耦合度是用来判断一个软件模块与其他软件模块之间的联系紧密情况。
二、软件耦合的分类
软件耦合按标准定义可分为7种耦合方式,分别是:内容耦合、公共耦合、外部耦合、控制耦合、标记耦合、数据耦合和非直接耦合。
三、七种耦合度的关系式
按照软件耦合度的定义可知七种耦合度的关系式为:
内容耦合 > 公共耦合 > 外部耦合 > 控制耦合 > 标记耦合 > 数据耦合 > 非直接耦合
四、耦合度的降低与解除
1、通过更改耦合方式降低耦合度;
2、通过设置数据传输方式降低耦合度;
3、通过软件分层降低耦合度。
五、每种耦合度的简介、存在的必要性及修改建议
1、内容耦合
1)简介
内容耦合是耦合度最高的耦合。所谓内容耦合即是一个模块(A模块)访问了另一个模块(B模块)内部的数据(注意:不是全局变量),导致A模块的运行状态受到B模块内容数据的影响或限制。
2)存在的必要性
没有必要存在。
3)修改建议
由于A模块的运行状态受到B模块内部数据的影响,要想了解A模块的运行状态必须要先了解B模块的内容数据,修改B模块时很有可能会对A模块的运行状态造成影响,降低了程序的可读性和可移植性。
所以说:内容耦合禁止存在,可通过其他耦合方式来代替内容耦合。
2、公共耦合
1)简介
公共耦合即是多个模块访问了相同的内容或使用了相同的内存空间(全局的结构体、联合体、上下位机公用的双口RAM区等)。
2)存在的必要性
是必定要存在的。
3)修改建议
由于多个模块共同使用一个结构体,会造成一个模块对结构体变量的修改影响其他模块的正常运行,不同模块对全局结构体的修改有可能会发生冲突等。所有说:只能通过设计合理的结构体变量来降低公共耦合的数量。
3、外部耦合
外部耦合和公共耦合是完全一样的,可参照公共耦合的介绍。
4、控制耦合
1)简介
控制耦合即是将一些相似功能强制封装在一起。
2)存在的必要性
不必要存在。
3)修改建议
由于控制耦合会导致被调用函数的一部分修改,会导致所有调用该函数的功能模块都会受到影响,所以说:将相似功能分为多个子功能,调用者调用不同的子功能函数执行响应动作。
5、标定耦合
标记耦合可参照U-boot向Linux kernel的参数传递机制。
6、数据耦合
1)简介
数据耦合即是不同模块之间通过数据参数(不是控制参数、全局结构体等)进行交换输入、输出信息的一种耦合方式。也就是多个模块之间通过模块接口传递的数据,比如函数的参数等。
2)存在的必要性
必须存在的。
3)修改建议
无。
7、非直接耦合
1)简介
非直接耦合即是两个模块之间没有直接联系,是通过主控模块的控制和调用产生联系的。
2)存在的必要性
必须会存在的。
3)修改建议
无。
网友评论