高内聚与低耦合是每个软件开发者追求的目标,那么内聚和耦合分别是什么意思呢?
不同模块之间的关系就是耦合,根据耦合程度可以分为7种,耦合度依次变低。
内容耦合
公共耦合
外部耦合
控制耦合
标记耦合
数据耦合
非直接耦合
案例:
m1和m2是两个独立的模块,其中m2会显示m1的输入,m1会显示m2的输入。
很显然,m1和m2两个模块之间会有一些联系(耦合),下面用7种不同的方式来实现这个功能。
内容耦合是最紧的耦合程度,一个模块直接访问另一模块的内容,则称这两个模块为内容耦合
在这个case中,将m1的输入放到m2.m1input上,将m2的输入放到m1.m2input上
一组模块都访问同一个全局数据结构,则称之为公共耦合。
在这个case中,m1和m2将自己的输入放到全局的data上
一组模块都访问同一全局简单变量,而且不通过参数表传递该全局变量的信息,则称之为外部耦合。外部耦合和公共耦合很像,区别就是一个是简单变量,一个是复杂数据结构。
在这个case中,m1和m2都将自己的输入放到全局上
模块之间传递的不是数据信息,而是控制信息例如标志、开关量等,一个模块控制了另一个模块的功能。
从控制耦合开始,模块的数据就放在自己内部了,不同模块之间通过接口互相调用。
在这个case中,得增加一个需求,就是当m1的输入为空时,隐藏m2的显示信息。
调用模块和被调用模块之间传递数据结构而不是简单数据,同时也称作特征耦合。
在这个case中,m1传给m2的是一个对象。
调用模块和被调用模块之间只传递简单的数据项参数。相当于高级语言中的值传递。
在这个case中,m1传给m2的是一个简单数据结构。
两个模块之间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现的。耦合度最弱,模块独立性最强。
子模块无需知道对方的存在,子模块之间的联系,全部变成子模块和主模块之间的联系。
在这个case中,增加一个主模块。
参考于:https://yanhaijing.com/program/2016/09/01/about-coupling/