软件工程-第五章-总体设计

  • 5. 总体设计
    • 5.1 设计过程
    • 5.2 设计原理
      • 5.2.1 模块化
      • 5.2.2 抽象
      • 5.2.3 逐步求精
      • 5.2.4 信息隐藏和局部化
      • 5.2.5 模块独立
    • 5.3 启发规则
    • 5.4 描述软件结构的图形工具
      • 5.4.1 层次图和 HIPO 图
      • 5.4.2 结构图
    • 5.5 面向数据流的设计方法
      • 5.5.1 概念
    • 习题

5. 总体设计

总体设计又称为概要设计或初步设计

5.1 设计过程

总体设计过程通常由两个主要阶段组成:

  • 系统设计阶段:确定系统的具体实现方案
  • 结构设计阶段:确定软件结构

典型的总体设计过程包括下述9个步骤:

  • 设想供选择的方案
  • 选取合理的方案
  • 推荐最佳方案
  • 功能分解
  • 设计软件结构
  • 设计数据库
  • 制定测试计划
  • 书写文档
  • 审查和复审

5.2 设计原理

5.2.1 模块化

模块是由边界元素限定的相邻程序元素(例如,数据说明,可执行的语句)的序列,而且有一个总体标识符代表它。

模块化就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。

5.2.2 抽象

把相似的方面集中和概括起来,暂时忽略它们之间的差异,这就是抽象。
抽象就是抽出事物的本质特性而暂时不考虑它们的细节。

5.2.3 逐步求精

逐步求精:为了能集中精力解决最主要问题而尽量推迟对问题细节的考虑。

逐步求精是人类解决复杂问题时采用的基本方法,也是许多软件工程技术的基础。

5.2.4 信息隐藏和局部化

信息隐藏:应该这样设计和确定模块,使得一个模块内包含的信息(过程和数据)对于不需要这些信息的模块来说是不能访问的。

局部化:是指把一些关系密切的软件元素物理地放得彼此靠近。

5.2.5 模块独立

模块独立的概念是模块化、抽象、信息隐藏和局部化概念的直接结果。

模块的独立程度可以由两个定性标准度量:

  • 内聚
  • 耦合
  1. 耦合:

耦合是对一个软件结构内不同模块之间互连程度的度量。
耦合强弱取决于模块间接口的复杂程度,进入或访问一个模块的点,以及通过接口的数据。
耦合程度强烈影响着系统的可理解性、可测试性、可靠性、可维护性。
设计原则:尽量使用数据耦合,少用控制耦合和特征耦合,限制公共环境的耦合的范围,完全不用内容耦合。

  • 数据耦合:如果两个模块彼此间通过参数交换信息,而且交换的信息仅仅是数据。数据耦合是低耦合。
  • 控制耦合:传递的信息中有控制信息(尽管有时这种控制信息以数据的形式出现)。控制耦合是中等程度的耦合,增加了系统的复杂程度。
  • 特征耦合:当整个数据结构作为参数传递而被调用的模块只需要使用其中一部分数据元素时。
  • 公共环境耦合:当两个或多个模块通过一个公共数据环境互相作用时。公共环境可以是全程变量、共享通信区、内存的公共覆盖区、任何存储介质的文件、物理设备等。
  • 内容耦合:最高程度的耦合,如果出现下列情况之一就是内容耦合:
    • ①一个模块访问另一个模块的内部数据
    • ②一个模块不通过正常入口而转到另一个模块的内部
    • ③两个模块有一部分程序代码重叠(只可能出现在汇编程序中)
    • ④一个模块有多个入口(这意味着一个模块有几种功能)
  1. 内聚:

内聚标志着一个模块内各个元素彼此之间结合的紧密程度,它是信息隐藏和局部化概念的扩展。
理想内聚的模块只做一件事情。
模块内的高内聚往往意味着模块间的低耦合。
设计原则:力求高内聚,并且能够辨认出低内聚的模块,有能力通过修改设计提高模块的内聚程度并且降低模块间的耦合程度,从而获得较高的模块独立性。

低内聚有如下几类:

  • 偶然内聚:如果一个模块完成一组任务,这些任务彼此之间有关系,关系也是很松散的。如在一个程序内有一组语句在两处或多处出现,于是把这些语句作为一个模块以节省内存。
  • 逻辑内聚:如果一个模块完成的任务在逻辑上属于相同或相似的一类。如一个模块产生各种类型的全部输出。
  • 时间内聚:如果一个模块包含的任务必须在同一时间内执行。如模块完成各种初始化工作。

中内聚:

  • 过程内聚:如果一个模块内的处理元素是相关的,且必须以特定次序执行。如流程图确定模块的划分,得到的往往是过程内聚的模块。
  • 通信内聚:如果一个模块中所有元素都使用同一个输入数据和(或)产生同一个输出数据。

高内聚:

  • 顺序内聚:如果一个模块内的处理元素和同一个功能密切相关,且这些处理必须顺序执行(通常一个处理元素的输出数据作为下一个处理元素的输入数据),则称为顺序内聚。根据数据流图划分模块得到往往是顺序内聚模块。
  • 功能内聚:如果模块内的所有处理元素属于一个整体,完成一个单一的功能,则称为功能内聚。功能内聚是最高程度的内聚。

7种内聚的优劣评分:

名称 评分
功能内聚 10
顺序内聚 9
通信内聚 7
过程内聚 5
时间内聚 3
逻辑内聚 1
偶然内聚 0

5.3 启发规则

  • 改进软件结构提高模块独立性
  • 模块规模应该适中
  • 深度、宽度、扇出和扇入都应适当
  • 模块的作用域应该在控制域内
  • 力争降低模块接口的复杂程度
  • 设计单入口单出口的模块
  • 模块的功能应该可以预测

5.4 描述软件结构的图形工具

5.4.1 层次图和 HIPO 图

层次图:用来描绘软件的层次结构。
层次图中的一个矩形框代表一个模块,方框间的连线表示调用关系而不像层次方框图那样表示组成关系。

HIPO图:“层次图加输入/处理/输出图”。就是在层次图里除了最顶层的方框之外,每个方框都加了编号。

5.4.2 结构图

一个方框代表一个模块,框内注明模块的名字或主要功能,方框间的箭头(或直线)代表模块的调用关系,注释表示来回传递的信息【尾部空心圆表示传递数据,实心圆代表传递控制信息】。

5.5 面向数据流的设计方法

5.5.1 概念

面向数据流的设计方法把信息流映射成软件结构,信息流的类型决定了映射的方法。
信息流有下述两种类型:

  1. 变换流:

信息沿输入通路进入系统,同时由外部形式变换成内部形式,进入系统的信息通过变换中心,经加工处理后再沿输出通路变换成外部形式离开软件系统。当数据流图具有这些特征时,这种信息流就叫做变换流。

  1. 事务流:

数据沿输入通路到达一个处理 T,这个处理根据输入数据的类型在若干个动作序列中选出一个来执行。这类数据流应该划为一类特殊的数据流,称为事务流。

习题

  1. 为每种类型的模块耦合举一个具体例子。
  • 数据耦合:比如图书管理系统的交欠款和处理逾期借书就是数据耦合,通过数据输入输出交流信息,为数据耦合。
  • 控制耦合:比如一个学生成绩查询系统,其查找模块就控制了查寻学生姓名、查询成绩等模块,为控制关系,是控制耦合。
  • 特征耦合:比如交电费和交水费本身没有直接关系,但都与用户的交款模块产生相似特征。
  • 公共环境耦合:如两个或多个模块对同一文件的读写操作。
  • 内容耦合。即有下列情况时即出现内容耦合。
    • (1)一个模块访问另一个模块数据;
    • (2)一个模块不通过正常入口而转到另一个模块的内部;
    • (3)两个模块有一部分代码重叠;
    • (4)一个模块有多个入口。
  1. 为每种类型的模块内聚举一个具体例子。
  • 偶然内聚:即模块内各部分之间没有联系,或者即使有联系也很松散,这种即为偶然内聚,它是内聚程度最低的模块。如一些没有任何联系的语句可能在许多模块中重复多次,程序员为了节省存储,把它们抽出来组成一个新的模块,这个模块就是偶然内聚模块。
  • 逻辑内聚:即这种模块把几种功能组合在一起,每次调用时,由传送给模块的判定参数来确定该模块应执行哪一种功能。如根据输入的控制信息,或从文件中读入一个记录,或向文件写出一个记录。
  • 时间内聚:这种模块大多数为多功能模块,但模块的各功能的执行与时间有关,通常要求所有功能必须在同一时间段内执行,例如初始化模块和终止模块。
  • 过程内聚:即一个模块内的处理是相关的,而且必须以特定次序执行,则这个模块称为过程内聚模块。例如我们把流程图中的循环部分、判定部分、计算部分分成三个模块,这三个模块都是过程内聚模块。
  • 通信内聚:如果一个模块内部各功能部分都使用可相同的数据输入, 或产生了可相同的数据输入,或产生了可相同的输出数据,则称之为通信内聚模块。通常,通信内聚模块是通过数据流图来定义的。
  • 顺序内聚:即一个模块内处理元素和同一功能紧密切相关,而且这些处理必须顺序执行(通常一个处理元素的输出数据据作为下一处理元素的输入数据)如在对员工加工资的数据库操作中,读取数据和更新数据即具有顺序内聚的关系。
  • 功能内聚:即模块内部所有处理元素属于一个整体,完成一个单一的功能, 则称为功能内聚,功能内聚是最高程度的内聚。

软件工程-第五章-总体设计相关推荐

  1. 软件工程第五章——总体设计

    总体设计的基本目的就是回答"概括地说,系统应该如何实现"这个问题,因此,总体设计又称为概要设计或初步设计. 总体设计阶段的另一项重要任务是设计软件的结构,也就是要确定系统中每个程序 ...

  2. 软件工程--第五章-- 总体设计

    文章目录 设计原理 模块化 ==模块独立性 (最重要的特性)== 抽象 逐步求精 启发式规则 图形工具 面向数据流的设计方法 概要设计说明书 系统的总体设计=概要设计/初步设计 这个阶段任务:划分出组 ...

  3. 软件工程复试——五、总体设计

    五.总体设计 总体设计又称为概要设计或初步设计.其基本目的就是回答"概括地说,系统应该如何实现"这个问题. 设计过程 总体设计过长一般分两个阶段组成:系统设计阶段,结构设计阶段. ...

  4. 软件工程导论第六版 第五章 总体设计知识点总结

    目录 总体设计概述 目的 任务 设计过程 设计原理 什么是模块?什么是模块化? 模块化的优点 模块化和软件成本 逐步求精 什么是逐步求精? Miller法则 抽象 信息隐藏和局部化 什么是信息隐藏 信 ...

  5. 软件工程 | 第五章 详细设计与实现

    软件工程 系列为本学期(2020春季)软件工程以及软件工程实践课程笔记整理~ 需求文档已经交了,设计文档还会远吗?从理论到实践,果然还有很多东西需要掌握 整理这部分笔记时想起了毕设学长的话,代码要让自 ...

  6. 软件工程导论 05章总体设计

    1.典型的总体设计步骤: ①确定最佳方案 ②功能分解 ③体系结构设计 ④模块设计 ⑤数据结构与数据库设计 ⑥用户界面设计 ⑦设计完成设计文档 ⑧评审 总体设计的目的:概括地回答系统应该如何实现这个问题 ...

  7. 现代软件工程 第五章 【团队和流程】练习与讨论

    团队模式和团队的开发模式有什么关系? 如果你领头开展一个全新的项目,你要怎么选择"合适"的团队模式? 不同的团队模式如何影响团队绩效的评估? 团队精神和集体主义的区别?     大 ...

  8. 软件工程——第五章(敏捷开发)

    1.敏捷软件开发的宣言 "我们正在通过亲身实践以及帮助他人实践的方式来揭示更好的软件开发之路,通过这项工作,我们认识到: 个人和这些人之间的交流胜过了开发过程和工具 可运行的软件胜过了宽泛的 ...

  9. 软件工程第五章3(1)

    转载于:https://www.cnblogs.com/sink1/p/4969810.html

最新文章

  1. java jsp页面如何添加C标签
  2. 【周末阅读】2019自动驾驶十大关键词
  3. 吞吐量达到瓶颈后下降_如何找到 Kafka 集群的吞吐量极限?
  4. python 合并排序的数组
  5. returnFunc.js
  6. 【机器学习基础】数学推导+纯Python实现机器学习算法4:决策树之ID3算法
  7. clientdataset 遍历字段_TClientDataSet[5]: 读取数据
  8. 列出本机安装的所有硬件设备
  9. Cisco 3550-EMI 交 换 机 配 置 教 程
  10. 解读OpenShift的逻辑架构和技术架构
  11. SharePoint 关于拓扑错误的解决方案
  12. Transformers Assemble(PART V)
  13. python增删改查mysql_Python操作MySQL(增删改查)
  14. ijcai2017赛后总结
  15. 如何有效的进行项目文档管理
  16. 2021年「博客之星」参赛博主:smileNicky投票
  17. 简析美颜sdk中的人脸识别算法
  18. 数学分析_Tom M.Apostol 定理7.6 用阿贝尔变换证明Riemann-Stieltjes积分的分部积分公式...
  19. 使用谷歌、360浏览器的F12功能模拟微信访问网页
  20. 肇庆学院计算机科学与技术专业多少分能进,2020肇庆学院录取分数线是多少-各专业分数线...

热门文章

  1. Websocket(二)-客户端与服务器通信
  2. 2023计算机毕业设计SSM最新选题之java中药城药材销售管理系统eah41
  3. vscode各种按键失效
  4. 计算机里被删除的文件可以在哪里进行恢复,电脑里的文件夹不小心删除了找回来的方法...
  5. debian中文输入法——拼音和五笔的解决方法
  6. OpenCV在图片上画线和矩形
  7. Audacity合成音频的软件
  8. 网络工程师模拟测试题
  9. 详解脑的功能区域分布以及布罗德曼分区系统
  10. 2012计算机科学排名,USNEWS2012年计算机科学专业研究生排名