高类聚与低耦合
内聚是从功能的角度来度量模块内的联系,一个好的内聚模块应该恰好做好一件事。它描述的是模块内的功能联系。
耦合是软件结构中各模块之间相互连接的一种度量,耦合强弱取决于模块间接口的复杂程度、进入或者访问一个模块的点以及通过接口的数据。
耦合
不同模块之间的关系就是耦合,根据耦合程度可以分为7种,耦合度依次变低。
-
内容耦合:一个模块直接访问另一个模块的内容,则称两个模块为内容耦合。
-
公共耦合:一组模块都访问一个全局数据结构,则称之为公共耦合。
-
外部耦合:一组模块都访问同一全局简单变量,而且不通过参数表传递该全局变量的信息,则称之为外部耦合。外部耦合和公共耦合很像,区别在于一个是简单变量,一个是复杂数据结构。
-
控制耦合:模块之间传递的不是数据信息,而是控制信息例如标志、开关量等。一个模块控制了另一个模块的功能。从控制耦合开始,模块的数据就放在自己内部了,不同模块之间通过接口调用。
-
标记耦合:调用模块和被调用模块之间传递数据结构而不是简单数据,同时也叫做特征耦合。
-
数据耦合:调用模块和被调用之间只传递简单的数据项参数。相当于高级语言中的值传递。
-
非直接耦合:两个模块之间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现,耦合度最弱,模块独立性最强。子模块无需知道对方的存在,子模块之间的联系,全部变成子模块和主模块之间的联系。
内聚
-
偶然内聚:如果一个模块的各成分之间毫无关系,则称为偶然内聚。模块完成一组任务,这些任务之间的关系松散,实际上没有什么联系。
-
逻辑内聚:几个逻辑相关的功能被放在同一模块中,则称为逻辑内聚。
-
时间内聚:如果一个模块完成的功能必须放在同一时间内执行,但这些功能只是因为时间关联在一起。
-
过程内聚:允许在调用前面的操作,马上调用后面的操作,即使两者之间没有数据进行传递,意思是两个操作有先后顺序,但不需要因为数据处理的前后因果关系造成的先后顺序,也可因数据处理的前后因果关系造成的先后顺序。、
-
通信内聚:如果一个模块所有成分都操作同一数据集或生成同一数据集,则称为通信内聚。
-
顺序内聚:一个模块的各个成分和同一功能密切相关,而且一个成分的输出作为另一个成分的输入。
-
功能内聚:模块的所有成分对于完成单一的功能都是必须的。意思是模块的成分为一个功能而聚集。