5.3 总体设计 - 设计原理之耦合
耦合
耦合是对软件结构中不同模块之间互连程度的度量。耦合强弱取决于模块间接口的复杂程度,进入或访问一个模块的点,以及通过接口的数据。在软件设计中,应追求尽可能松散耦合的系统。
耦合类型
非直接耦合(Nondirect Coupling)
- 定义:两个模块之间没有直接关系,通过主模块的控制和调用来实现联系。
- 特点:模块独立性最强。
数据耦合(Data Coupling)
- 定义:模块间通过简单数据参数交换信息。
- 特点:低耦合。
标记耦合(Stamp Coupling)
- 定义:模块通过参数表传递记录信息。
- 特点:数据结构上的操作复杂化,可消除或转化为数据耦合。
控制耦合(Control Coupling)
- 定义:一个模块通过传送控制信息控制另一个模块的功能。
- 特点:中等耦合度,降低模块独立性。
外部耦合(External Coupling)
- 定义:模块访问同一全局简单变量。
- 问题:
- 无法控制公共数据的存取,影响可靠性和适应性。
- 降低程序可读性。
公共耦合(Common Coupling)
- 定义:模块访问同一个公共数据环境。
- 问题:
- 修改数据大小影响所有模块。
- 无法控制公共数据的存取,影响可靠性和适应性。
- 降低程序可读性。
内容耦合(Content Coupling)
- 定义:一个模块直接访问另一个模块的内部数据或程序代码重叠。
- 特点:耦合度最高,现代高级语言不允许。
设计指导原则
- 尽量使用数据耦合。
- 少用控制耦合和特征耦合。
- 限制外部耦合和公共耦合。
- 完全不用内容耦合。
降低耦合度的方法
- 根据问题特点选择适当的耦合类型。
- 降低模块接口的复杂性(信息数量、联系方式、信息结构)。
- 把模块的通信信息放在缓冲区中。
- 减少公共区,使之局部化,划分为逻辑子区。
- 输入输出局限在少数模块,不要分散在全系统。