- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
結构化设计方法
§4.2 结构化设计方法
软件设计分为两个阶段:
(1)概要设计(总体设计)
确定软件的结构以及各组成成分
(子系统或模块)之间的相互关系。
(2)详细设计
确定模块内部的算法和数据结构,产生描述各模块程序过程的详细文档。
将分析模型转换为软件设计
数据
字典
数据
流图
E-R图
状态变迁图
加
工
说
明
控制说明
数
据
对
说
明
象
数 据 设 计
体系结构设计
接口设计
过程设计
分析模型
设计模型
4.2.1 软件设计的概念和原理
1. 软件结构
2. 软件过程
3. 模块化
4. 抽象
5. 信息隐蔽
6. 信息局部化
4.2.6 模块的独立性
模块独立的含义:
模块完成独立的功能
符合信息隐蔽和信息局部化原则
模块间关连和依赖程度尽量小
模块独立性的度量
模块独立性取决于模块的内部和外部特征。
SD方法提出的定性的度量标准:
模块之间的耦合性
模块自身的内聚性
模块间耦合的类型:
低 无直接耦合
耦 数据耦合
合 标记耦合
性 控制耦合
外部耦合
公共耦合
高 内容耦合
模
块
独
立
性
弱
(低耦合)
强
(中耦合)
(较强耦合)
(强耦合)
(1) 无直接耦合
两个模块没有直接关系(模块1和模块2),模块独立性最强。
模块1
模块2
模块3
模块4
(2) 数据耦合
一模块调用另一模块时,被调用模块的输入、输出都是简单的数据(若干参数)。
属松散耦合。
数据耦合举例
开发票
计算水费
单价
数量
金额
(3) 标记耦合(特征耦合)
如两个模块通过传递数据结构
(不是简单数据,而是记录、数组
等)加以联系,或都与一个数据
结构有关系, 则称这两个模块
间存在标记偶合。
标记耦合举例
计算水电费
计算水费
计算电费
住户情况
水费
电费
住户情况
“住户情况”是一个数据结构,图中模块都
与此数据结构有关.
“计算水费”和“计算电费”本无关,由于
引用了此数据结构产生依赖关系,它们之间
也是标记偶合.
将标记耦合修改为数据耦合举例
计算水电费
计算水费
计算电费
本月
用水量
本月
用电量
水费
电费
(4) 控制耦合
一模块向下属模块传递的信息 (开关量、标志等控制被调用模块决策的变量) 控制了被调用模块的内部逻辑。
控制耦合举例
A
计算平均分
或最高分
B
平均/最高
(控制信号)
成绩
读入分数
输出结果
计算平均分
计算最高分
平均/最高?
B
控制耦合增加了理解和编程的复
杂性,调用模块必须知道被调模
块的内部逻辑,增加了相互依赖
去除模块间控制耦合的方法:
(1)将被调用模块内的判定上移到调
用模块中进行
(2)被调用模块分解成若干单一功
能模块
改控制耦合为数据耦合举例
A
计算平均分
B1
平均成绩
最高成绩
计算最高分
B2
(5) 外部耦合
一组模块均与同一外部环境关联
(例如,I/O模块与特定的设备、
格式和通信协议相关联),它们之
间便存在外部耦合。
外部偶合必不可少,但这种模块
数目应尽量少。
(6) 公共耦合(公共数据区耦合)
一组模块引用同一个公用数据区
(也称全局数据区、公共数据环境)。
公共数据区指:
全局数据结构
共享通讯区
内存公共覆盖区等
公共耦合举例
A
公共数据区
C
B
模块A、B、C间存在错综复杂的联系
(1)软件可理解性降低
(2)诊断错误困难
(3)软件可维护性差,
(4)软件可靠性差
(公共数据区及全程变量无保护措施)
慎用公共数据区和全程变量!!!
公共耦合存在的问题:
(7) 内容耦合
一模块直接访问
另一模块的内部
信息 (程序代码
或数据)
最不好的耦合形式 !!!
A
B
A
B
模块代码重叠
Entry1
……
Entry1
……
多入口模块
模块化设计的原则和目标
耦合是影响软件复杂程度和设计质量的重要因素
目标:建立模块间耦合度尽可能
松散的系统
如何降低模块间耦合度:
(1) 尽量使用数据耦合
少用控制耦合
限制公共耦合的范围
坚决避免使用内容耦合
(2) 降低接口的复杂性
2. 模块独立性的度量之二:内聚性
一个模块内部元素在功能上相互关联的强度
设计目标:高内聚
(模块在软件过程中
完成单一的任务)
模块的内聚性类型:
低 偶然内聚
内 逻辑内聚
聚 时间内聚
性 过程内聚
文档评论(0)