这个不等式导致“各个击破” 的结论—把复杂的问题分解成 许多容易解决的小问题,原来
的问题也就容易解决了。这就
是模块化的根据。
第10页/共72页
最小成本区
M
总成本 接口成本
模块成本 模块数
4.2.2 抽象
人类在认识复杂现象的过程中使用的最强有力的思维工具是 抽象。
-- 就是抽出事物的本质特性(共性),而暂时不考虑它们的细节。 处理复杂系统的惟一有效的方法是用层次的方式构造和分析
如两个模块通过传
计算电费
递数据结构(不是 住户情况
住户情况
简单数据,而是
记录、数组等)加 以联系,或都与
水费 电费
计算水费
计算水电费
一个数据结构有 关系, 则称这两个
“住户情况”是一个数据结构,图中 模块都与此数据结构有关.“计算水 费”和“计算电费”本无关,由于引
模块间存在标记
用了此数据结构产生依赖关系,它们 之间也是标记偶合.
第9页/共72页
问题:模块该如何划分?
设:C(x)为复杂程度函数
E(x)为决定解决问题x所需的
工作量(时间)函数
软
件
对于两个问题P1和P2,
开
如果 C(P1)>C(P2)
发 工
则: E(P1)>E(P2)
作
量
如果 C(P1+P2)>C(P1)+C(P2)
则: E(P1+P2)>E(P1)+E(P2)
如果在测试期间和以后的软件维护期间需要修改软件, 那么使用信息隐藏原理作为模块化系统设计的标准就会 带来极大好处。
第15页/共72页
4.2.5 模块独立