软件工程第5章总体设计.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《软件工程第5章总体设计.ppt》由会员分享,可在线阅读,更多相关《软件工程第5章总体设计.ppt(86页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第五章第五章总总 体体 设设 计计 可行性分析可行性分析-Why?Who?Why?Who?需求分析需求分析 -What?What?设计设计 -How do?How do?总体设计总体设计(概要设计概要设计)确定软件的结构以及确定软件的结构以及 各组成成分各组成成分(子系统或模块子系统或模块)之间的相互关系之间的相互关系 设计设计 详细设计确定模块内部的算法和数据结构,详细设计确定模块内部的算法和数据结构,产生描述各模块程序过程的详细文档。产生描述各模块程序过程的详细文档。总体设计的任务v划分出组成系统的物理元素划分出组成系统的物理元素程序、文程序、文件、数据库、人工过程和文档等,但是件、数据库
2、、人工过程和文档等,但是每个物理元素仍然处于黑盒子级,这些每个物理元素仍然处于黑盒子级,这些黑盒子里的具体内容将在以后仔细设计。黑盒子里的具体内容将在以后仔细设计。v设计软件的结构设计软件的结构,也就是要确定系统中,也就是要确定系统中每个程序是由哪些模块组成的,以及这每个程序是由哪些模块组成的,以及这些模块相互间的关系。些模块相互间的关系。v总体设计的必要性:可以站在全局高度上,花较少成本,从较抽象的层次上分析对比多种可能的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。5.1 设计过程v总体设计过程通常由两个主要阶段组成:总体设计过程通常由
3、两个主要阶段组成:-系统设计阶段,确定系统的具体实系统设计阶段,确定系统的具体实现方案;现方案;-结构设计阶段,确定软件结构。结构设计阶段,确定软件结构。v典型的总体设计过程包括典型的总体设计过程包括:1.设想供选择的方案设想供选择的方案 2.选择合理的方案选择合理的方案 对每个合理的方案要提供:对每个合理的方案要提供:A系统流程图系统流程图 B组成系统的物理元素清单组成系统的物理元素清单 C成本成本/效益分析效益分析 D实现这个系统的进度计划实现这个系统的进度计划 3.推荐最佳方案推荐最佳方案4.功能分解功能分解5.设计软件结构设计软件结构6.数据库设计数据库设计 A模式设计模式设计 B子模
4、式设计子模式设计 C完整性和安全性设计完整性和安全性设计 D优化优化 7.制定测试计划制定测试计划8.书写文档书写文档 A系系统统说说明明:包包括括用用系系统统流流程程图图描描绘绘的的系系统统构构成成方方案案,组组成成系系统统的的物物理理元元素素清清单单,成成本本/效效益益分分析析;对对最最佳佳方方案案的的概概括括描描述述,精精化化的的数数据据流流图图,用用层层次次图图或或结结构构图图描描绘绘的的软软件件结结构构,用用IPOIPO图图或或其其他他工工具具简简要要描描述述的的各各个个模模块块的的算算法法,模模块块间间的的接接口口关关系系,以以及及需需求求、功功能能和和模模块块三三者者之之间间的的
5、交交叉参照关系等等。叉参照关系等等。B B用用户户手手册册:根根据据总总体体设设计计阶阶段段的的结结果果,修修改改更更正正在在需需求分析阶段产生的初步的用户手册。求分析阶段产生的初步的用户手册。C C测测试试计计划划:包包括括测测试试策策略略,测测试试方方案案,预预期期的的测测试试结结果,测试进度计划等等。果,测试进度计划等等。D详细的实现计划详细的实现计划 E数据库设计结果数据库设计结果9.审查和复审审查和复审 5.2 设计原理v 模块化模块化v 抽抽 象象v 逐步求精逐步求精v 信息隐藏和局部化信息隐藏和局部化v 模块独立模块独立5.2.1 模块化v模块模块是由边界元素限定的相邻程序元素(
6、例是由边界元素限定的相邻程序元素(例如,数据说明,可执行的语句)的序列,而如,数据说明,可执行的语句)的序列,而且有一个总体标识符代表它。且有一个总体标识符代表它。-如:过程、函数、子程序、宏、对象等,都可作为模块。如:过程、函数、子程序、宏、对象等,都可作为模块。v模块化模块化就是把程序划分成独立命名且可独立就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。指定的功能满足用户的需求。v这个不等式导致这个不等式导致“各个击破各个击破”的
7、结论的结论把复杂的问把复杂的问题分解成许多容易解决的小问题,原来的问题也就题分解成许多容易解决的小问题,原来的问题也就容易解决了。这就是模块化的根据。容易解决了。这就是模块化的根据。如果一个大型程序仅由一个模块组成,很难被如果一个大型程序仅由一个模块组成,很难被人理解。人理解。设函数设函数C(x)定义问题定义问题x的复杂程度,函数的复杂程度,函数E(x)定义解决问题定义解决问题x需要的工作量(时间)。需要的工作量(时间)。对于两个问题对于两个问题P1和和P2,如果:,如果:C(P1)C(P2)那么那么 E(P1)E(P2)根据解决问题的经验,有一个规律是:根据解决问题的经验,有一个规律是:C(
8、P1+P2)C(P1)+C(P2)于是有于是有 E(P1+P2)E(P1)+E(P2)模块数目模块数目接口成本接口成本成本成本/模块模块软件总成本软件总成本M最小成本区最小成本区成成本本图图5.1 模块化与软件成本模块化与软件成本5.2.2 抽象v人类在认识复杂现象的过程中使用的最强有力的思维工具是抽象。-就是抽出事物的本质特性(共性),而暂时不考虑它们的细节。v处理复杂系统的惟一有效的方法是用层次的方式构造和分析它。-在抽象的最高层次使用问题环境的语言,以概括的方式叙述问题的解法;在较低抽象层次采用更过程化的方法,把面向问题的术语和面向实现的术语结合起来叙述问题的解法;最后在最低的抽象层次用
9、可直接实现的方式叙述问题的解法。v软件工程过程的每一步都是对软件解法的抽象层次的一次精化。在可行性研究阶段,软件作为系统的一个完整部件;在需求分析期间,软件解法是使用在问题环境内熟悉的方式描述的;当由总体设计向详细设计过渡时,抽象的程度也就随之减少了;最后,当源程序写出来以后,也就达到了抽象的最低层。5.2.3 逐步求精逐步求精是人类解决复杂问题时采用的基逐步求精是人类解决复杂问题时采用的基本方法,也是许多软件工程技术(例如,本方法,也是许多软件工程技术(例如,规格说明技术,设计和实现技术)的基础。规格说明技术,设计和实现技术)的基础。逐步求精定义为:逐步求精定义为:“为了能集中精力解决为了能
10、集中精力解决主要问题而尽量推迟对问题细节的考虑。主要问题而尽量推迟对问题细节的考虑。”5.2.4 信息隐藏和局部化v信息隐藏原理指出:设计和确定模块,使得一个模信息隐藏原理指出:设计和确定模块,使得一个模块内包含的信息块内包含的信息(过程和数据过程和数据)对于不需要这些信息对于不需要这些信息的模块来说,是不能访问的。的模块来说,是不能访问的。v局部化的概念和信息隐藏概念是密切相关的。局部化的概念和信息隐藏概念是密切相关的。v所谓局部化:是指把一些关系密切的软件元素物理所谓局部化:是指把一些关系密切的软件元素物理地放得彼此靠近。地放得彼此靠近。-在模块中使用局部数据元素是局部化的一个例在模块中使
11、用局部数据元素是局部化的一个例子。显然,局部化有助于实现信息隐藏。子。显然,局部化有助于实现信息隐藏。v如果在测试期间和以后的软件维护期间需要修改软如果在测试期间和以后的软件维护期间需要修改软件,那么使用信息隐藏原理作为模块化系统设计的件,那么使用信息隐藏原理作为模块化系统设计的标准就会带来极大好处。标准就会带来极大好处。5.2.5 模块独立耦合耦合耦合耦合 模块之间的模块之间的模块之间的模块之间的相对独立性相对独立性相对独立性相对独立性的度量的度量的度量的度量 内聚内聚内聚内聚模块功能强模块功能强模块功能强模块功能强度的度量度的度量度的度量度的度量 模块的独立程度可以由两个定性标准度量模块的
12、独立程度可以由两个定性标准度量模块的独立性模块的独立性是指软件系统中每个模块只涉及软是指软件系统中每个模块只涉及软件要求的具体的子功能,而和软件系统中其他模件要求的具体的子功能,而和软件系统中其他模块的接口是简单的。块的接口是简单的。1.耦合 耦合性是程序结构中各个模块之间相互关联的度量耦合性是程序结构中各个模块之间相互关联的度量它取决于各个模块之间接口的复杂程度、调用模块的方它取决于各个模块之间接口的复杂程度、调用模块的方式以及哪些信息通过接口。式以及哪些信息通过接口。低低非直接非直接耦合耦合数据数据耦合耦合标记标记耦合耦合控制控制耦合耦合外部外部耦合耦合公共公共耦合耦合内容内容耦合耦合 高
13、高弱弱 强强耦合性耦合性模块独立性模块独立性(1)非直接耦合两个模块没有直接关系两个模块没有直接关系(模块模块1和模块和模块2),模块独立性最强。模块独立性最强。模块模块1 1模块模块2 2模块模块3 3模块模块4 4(2)数据耦合 一模块调用另一一模块调用另一模块时,被调用模块时,被调用模块的输入、输模块的输入、输出都是简单的数出都是简单的数据据(若干参数若干参数)。属松散耦合。属松散耦合。开发票开发票计算水费计算水费单价单价数量数量金金额额(3)标记耦合(特征耦合)如两个模块通过传如两个模块通过传递递数据结构数据结构(不是简不是简单数据,而是记录、单数据,而是记录、数组等数组等)加以联系,
14、加以联系,或都与一个或都与一个数据结数据结构构有关系有关系,则称这则称这两个模块间存在标两个模块间存在标记偶合。记偶合。“住户情况住户情况”是一个数据结构是一个数据结构,图中模块都与此数据结构有关图中模块都与此数据结构有关.“.“计算水费计算水费”和和“计算电费计算电费”本无关本无关,由于引用了此数据结构由于引用了此数据结构产生依赖关系产生依赖关系,它们之间也是标它们之间也是标记偶合记偶合.计算电费计算电费计算水费计算水费住户情况住户情况水费水费 电费电费住户情况住户情况计算水电费计算水电费(4)控制耦合A 模块flagf1Bf2fn 如果一个模块通过传送开关、标志、名字如果一个模块通过传送开
15、关、标志、名字 等等控制信息,明显地控制选择另一模块的功能,控制信息,明显地控制选择另一模块的功能,就是控制耦合。就是控制耦合。控制耦合增加了理解和编程的复杂性,调控制耦合增加了理解和编程的复杂性,调用模块必须知道被调模块的内部逻辑,增用模块必须知道被调模块的内部逻辑,增加了相互依赖。加了相互依赖。去除模块间控制耦合的方法:去除模块间控制耦合的方法:将被调用模块内的判定移到调用模块中进行将被调用模块内的判定移到调用模块中进行被调用模块分解成若干单一功能模块被调用模块分解成若干单一功能模块(5)外部耦合v一组模块均与同一外部环境关联一组模块均与同一外部环境关联(例如例如,I/OI/O模块与特定的
16、设备、格式和通信协模块与特定的设备、格式和通信协议相关联议相关联),),它们之间便存在外部耦合。它们之间便存在外部耦合。v外部偶合必不可少外部偶合必不可少,但这种模块数目应但这种模块数目应尽量少。尽量少。(6)公共环境耦合(公共数据区耦合)一组模块引用同一一组模块引用同一个公用数据区个公用数据区(也称也称全局数据区、公共全局数据区、公共数据环境数据环境)。公共数据区指:公共数据区指:v 全局数据结构全局数据结构v 共享通讯区共享通讯区v 内存公共覆盖区等内存公共覆盖区等 ABC公共数据区公共数据区 公共耦合存在的问题:公共耦合存在的问题:(1)软件可理解性降低软件可理解性降低 (2)诊断错误困
17、难诊断错误困难 (3)软件可维护性差,软件可维护性差,(4)软件可靠性差软件可靠性差(公共数据区公共数据区及全程变量无保护措施及全程变量无保护措施)慎用公共数据区和全程变量慎用公共数据区和全程变量!(7)内容耦合A B一模块直接访一模块直接访问另一模块的问另一模块的内部信息内部信息(程程序代码或数据)序代码或数据)A B 模模块块代代码码重重叠叠Entry1 Entry2 多多入入口口模模块块不不正正常常转转入入另另一一模模块块最不好的耦合形式!最不好的耦合形式!以上给出了以上给出了 7 7种耦合类型,这只是从耦合的机制种耦合类型,这只是从耦合的机制上所做的分类,按耦合的强弱程度的排列只是相上
18、所做的分类,按耦合的强弱程度的排列只是相对的关系。但它给设计人员在设计程序结构时提对的关系。但它给设计人员在设计程序结构时提供了一决策准则。实际上,开始时两个模块之间供了一决策准则。实际上,开始时两个模块之间的耦合不只是一种类型,而是多种类型的混合。的耦合不只是一种类型,而是多种类型的混合。这就要求设计人员按照实际情况进行分析比较,这就要求设计人员按照实际情况进行分析比较,逐步加以改进,以提高模块的独立性。逐步加以改进,以提高模块的独立性。总之,耦合是影响软件复杂程度的一个重要因素。总之,耦合是影响软件复杂程度的一个重要因素。应该采取下述设计原则:应该采取下述设计原则:尽量使用数据耦合,少用控
19、制耦合和标记耦合,尽量使用数据耦合,少用控制耦合和标记耦合,限制公共环境耦合的范围,完全不用内容耦合。限制公共环境耦合的范围,完全不用内容耦合。2.内 聚 v一个模块内部元素在功能上相互关联的强度一个模块内部元素在功能上相互关联的强度设计目标:高内聚,模块在软件过程中完成单一的设计目标:高内聚,模块在软件过程中完成单一的任务任务(1)功能内聚(Functional Cohesion)v一个模块中各个部分都是一个模块中各个部分都是完成某一完成某一具体功能具体功能必不可少的组成部分,或必不可少的组成部分,或者说该模块中所有部分都是为了完者说该模块中所有部分都是为了完成一项具体功能而协同工作,紧密成
20、一项具体功能而协同工作,紧密联系,不可分割的。则称该模块为联系,不可分割的。则称该模块为功能内聚模块。功能内聚模块。内聚性最强内聚性最强(2)信息内聚(Informational Cohesion)v这种模块完成多个功能,这种模块完成多个功能,各个功能都在同一数据各个功能都在同一数据结构上操作,每一项功结构上操作,每一项功能有一个唯一的入口点。能有一个唯一的入口点。模块将根据不同的要求,模块将根据不同的要求,确定该执行哪一个功能。确定该执行哪一个功能。由于模块的所有功能都由于模块的所有功能都是基于同一数据结构是基于同一数据结构(符号表),因此,它(符号表),因此,它是一个信息内聚的模块。是一个
21、信息内聚的模块。信息内聚模块可以看成是多个信息内聚模块可以看成是多个功能内聚模块的组合,并且达功能内聚模块的组合,并且达到信息的隐蔽。即把某个数据到信息的隐蔽。即把某个数据结构、资源或设备隐蔽在一个结构、资源或设备隐蔽在一个模块内,不为别的模块所知晓模块内,不为别的模块所知晓(3)通信内聚(Communication Cohesion)v如果一个模块内各如果一个模块内各功能部分都使用了功能部分都使用了相同的输入数据,相同的输入数据,或产生了相同的输或产生了相同的输出数据,则称之为出数据,则称之为通信内聚模块。通通信内聚模块。通常,通信内聚模块常,通信内聚模块是通过数据流图来是通过数据流图来定义
22、的。定义的。(4)过程内聚(Procedural Cohesion)模块内各处理成分相关,且必须以特定模块内各处理成分相关,且必须以特定次序执行次序执行统计统计成绩成绩打印打印成绩成绩统计并打印统计并打印成绩单成绩单读入读入成绩单成绩单审查审查成绩单成绩单读入并审读入并审查成绩单查成绩单(5)时间内聚(Classical Cohesion)时间内聚又称为经典内聚。这种模块大时间内聚又称为经典内聚。这种模块大多为多功能模块,但模块的各个功能的多为多功能模块,但模块的各个功能的执行与时间有关,通常要求所有功能必执行与时间有关,通常要求所有功能必须在同一时间段内执行。须在同一时间段内执行。例如初始化
23、模块和终止模块例如初始化模块和终止模块,系统结束系统结束模块、紧急故障处理模块等均是时间性模块、紧急故障处理模块等均是时间性聚合模块聚合模块 。如如图图,在在“紧紧急急故故障障处处理理模模块块”中中,“关关闭闭文文件件”、“报报警警”、“保保留留现现场场”等等任任务务都都必必须须无无中中断地同时处理。断地同时处理。紧急故障处理紧急故障处理模块模块1关闭文件关闭文件2报警报警3保留现场保留现场时间内聚示例时间内聚示例(6)逻辑内聚(Logical Cohesion)v把几种相关功能(逻辑上相似的功能)组合在把几种相关功能(逻辑上相似的功能)组合在一模块内,每次调用由传给模块的参数确定执一模块内,
24、每次调用由传给模块的参数确定执行哪种功能。行哪种功能。SXYZWABCDSXYZW ABCDX,Y,Z,W分别调用分别调用A,B,C,D,而而模块模块 A,B,C,D确完成的任务相确完成的任务相似(如产生各种类型的全部输似(如产生各种类型的全部输出),则我们把出),则我们把A,B,C,D 合并合并成一个模块成一个模块ABCD,那么我们,那么我们称模块称模块ABCD就是逻辑模块。就是逻辑模块。(7)巧合内聚(Coincidental Cohesion)v当模块内各部分之当模块内各部分之间没有联系,或者间没有联系,或者即使有联系,这种即使有联系,这种联系也很松散,则联系也很松散,则称此模块为巧合内
25、称此模块为巧合内聚模块,它是内聚聚模块,它是内聚程度最低的模块。程度最低的模块。模块模块MM中的三个语句没有任何联系中的三个语句没有任何联系缺点:可理解性差,缺点:可理解性差,可修改性差可修改性差v内聚与耦合密切相关,同其它模块强耦合内聚与耦合密切相关,同其它模块强耦合的模块意味者弱内聚,强内聚模块意味着的模块意味者弱内聚,强内聚模块意味着与其它模块间松散耦合。与其它模块间松散耦合。设计目标:设计目标:力争强内聚、弱耦合力争强内聚、弱耦合耦合、内聚与模块独立性关系:耦合、内聚与模块独立性关系:耦合与内聚都是模块独立性的定性标准,都反耦合与内聚都是模块独立性的定性标准,都反映模块独立性的良好程度
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 总体 设计
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内