模块内聚和耦合的基础知识是软件评测师考试的重要考点,经常出现在上午场的客观选择题当中。模块独立是指模块只完成系统要求的独立的子功能,并且与其他模块的接口简单,符合信息隐蔽和信息局部化原则,模块间关联和依赖程度尽可能小。衡量模块独立性的标准是耦合度和内聚度。内聚度是衡量同一个模块内部的各个元素彼此结合的紧密程度。耦合度是衡量不同模块彼此间相互依赖的紧密程度。下面就该知识点并结合例题进行总结学习。


一、模块内聚

(1)概述:内聚是一个模块内部各个元素彼此结合的紧密程度的度量。一个内聚程度高的模块(在理想情况下)应当只做一件事。

(2)分类:一般模块的内聚性分为7种类型,如下图所示:

1)偶然(巧合)内聚:模块完成的动作之间没有任何关系,或者仅仅是一种非常松散的关系。

2)逻辑内聚:指模块内执行若干个逻辑上相似的功能,通过参数确定该模块完成哪一个功能。

3)瞬时(时间)内聚:模块内部的各个组成部分所包含的处理动作必须在同一时间间隔内执行,例如初始化模块。

4)过程内聚:指一个模块完成多个任务,这些任务必须按指定的过程执行。

5)通信(信息)内聚:指模块内的所有处理元素都在同一个数据结构上操作,或者各处理使用相同的输入数据或者产生相同的输出数据。

6)顺序内聚:指一个模块中的各个处理元素都密切相关于同一功能且必须顺序执行,前一功能元素的输出就是下一功能元素的输入。

7)功能内聚:指模块内的所有元素共同作用完成一个功能,缺一不可,这是最强的内聚。


二、模块耦合

(1)概述:耦合是模块之间的相对独立性(互相连接的紧密程度)的度量。耦合取决于各个模块之间接口的复杂程度、调用模块的方式以及通过接口的信息类型等。

(2)分类:一般来说,模块之间的耦合有7种类型,如下图所示:

1)非直接耦合(无直接耦合):两个模块之间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现的,它们之间不传递任何信息,因此模块间的耦合性最弱,模块独立性最高。

2)、数据耦合:指两个模块之间有调用关系,传递的是简单的数据值(不是控制参数,公共数据结构或外部变量),相当于高级语言中的值传递。

3)标记耦合:指两个模块之间通过参数表(数据结构)传递记录信息。

4)控制耦合:指一个模块调用另一个模块时,传递的是控制变量,被调用模块通过该控制变量的值有选择地执行模块内的某一功能。因此,被调用模块内应具有多个功能,那个功能起作用受调用模块控制。也就是说一个模块通过传送开关、标志、名字等控制信息,明显地控制选择另一模块的功能。

5)外部耦合:模块间通过软件之外的环境联结( 如I/O将模块耦合到特定的设备、格式、通信协议上)时称为外部耦合。

6)公共耦合:指通过一个公共数据环境相互作用的那些模块间的耦合。

7)内容耦合:一个模块直接访问另一个模块的内部数据,或者通过非正常入口转入另一个模块内部,或者两个模块有一部分程序代码重叠,又或者一个模块有多种入口。这种模块之间的耦合称之为内容耦合。