参考:https://www.cnblogs.com/xiaym896/p/5400677.html
学习中补上些自己的理解。
一、内聚
1、偶然内聚:模块的各成分之间没有关联,只是把分散的功能合并在一起。
//程序1
double d1,d2,d3;
if(d1 > d2)
d3 = d1;
else
d3 = d2;
//程序2
int i1,i2,i3;
if(i1 > i2)
i3 = i1;
else
i3 = i2;
以上分别是int double型求最值,没有关联,而都是进行同样的操作求max,故把他们进行合并成一个模块。(可用c++的模板)
2、逻辑内聚:逻辑上相关的功能被放在同一模块中。
例:A模块实现的是将对应的人员信息发送给技术部,人事部和财政部,决定发送给哪个部门是输入的控制标志决定的。
人员信息发送(任务)的结果是“发送给技术部,人事部和财政部”,他们在逻辑上都是要进行处理人员信息,故属于类似的一类。所以,模块A中就是逻辑内聚。
3、时间内聚:模块完成的功能必须在同一段时间内执行。(但这些功能只是因为时间因素才有关联。)
例:class类的构造函数的初始化信息,必须得是同一段时间内执行。
4、过程内聚:模块内部的处理成分是相关的,而且这些处理必须以特定的次序进行执行。
例:用户进行购买商品(先付后用)场景中,用户订单生效的前提是他得付款。故对于购买支付这个模块,其内部得是:付款->订单生效。
5、通信内聚:模块的所有成分都操作同一数据集或生成同一数据集。
例:模块A实现将传入的Date类型数据转换成String类型,以及将Date类型数据插入数据库,这两个操作都是对“Date类型数据”而言的。模块A中就是通信内聚。
6、顺序内聚:模块的各个成分和同一个功能密切相关,而且一个成分的输出作为另一个成分的输入。
例:查询用户的密码场景中,用户输入的账户ID是到数据库中查询用户密码的输入。没有用户ID怎么查其对应的密码呢?
7、功能内聚:模块的所有成分对于完成单一的功能都是必须的。(成分没有多余)
例:模块A实现将新注册的用户信息(用户名,密码,个性签名)全部转换成String类型并插入数据库。模块A中就是功能内聚。