软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)

PPT
  • 阅读 218 次
  • 下载 0 次
  • 页数 113 页
  • 大小 1.741 MB
  • 2023-07-24 上传
  • 收藏
  • 违规举报
  • © 版权认领
下载文档22.00 元 加入VIP免费下载
此文档由【精品优选】提供上传,收益归文档提供者,本网站只提供存储服务。若此文档侵犯了您的版权,欢迎进行违规举报版权认领
软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)
可在后台配置第一页与第二页中间广告代码
软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)
可在后台配置第二页与第三页中间广告代码
软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)
可在后台配置第三页与第四页中间广告代码
软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)
软件工程导论课件之第5章 总体设计(第五版)(张海潘编著)
还剩10页未读,继续阅读
【这是免费文档,您可以免费阅读】
/ 113
  • 收藏
  • 违规举报
  • © 版权认领
下载文档22.00 元 加入VIP免费下载
文本内容

【文档说明】软件工程导论课件之第5章 总体设计(第五版)(张海潘编著).pptx,共(113)页,1.741 MB,由精品优选上传

转载请保留链接:https://www.ichengzhen.cn/view-290963.html

以下为本文档部分文字说明:

第5章总体设计5.1设计过程5.2设计原理5.3启发规则5.4描绘软件结构的图形工具5.5面向数据流的设计方法软件设计宣言:MitchKapor◼“什么是设计?设计是你站在两个世界——技术世界和人类的目标

世界——而你尝试将这两个世界结合在一起……”。罗马建筑批评家Vitruvius提出的观念:◼“设计良好的建筑应该展示出坚固、适用和令人赏心悦目”。设计阶段:◼从工程管理的角度,可以将软件设计分为概要设计阶段和详细设计阶段。◼从技术的角度,传统的结构化方法将

软件设计划分为体系结构设计、数据设计、接口设计和过程设计4部分。◼面向对象方法则将软件设计划分为体系结构设计、类设计/数据设计、接口设计和构件级设计4部分。结构化设计和结构化分析的关系:数据对象描述实体-关系图状态转换图控制规格说明数据流图处理规格说明数据字典数据设计体

系结构设计接口设计过程设计◼总体设计过程:首先寻找实现目标系统的各种不同的方案;然后分析员从这些供选择的方案中选取若干个合理的方案,从中选出一个最佳方案向用户和使用部门负责人推荐;分析员应该进一步为这个最佳方案设计软件结构,进行必要的数据

库设计,确定测试要求并且制定测试计划。◼必要性:总体设计可以站在全局高度上,花较少成本,从较抽象的层次上分析对比多种可能的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。5.1设计过程

由两个主要阶段组成:◼系统设计阶段,确定系统的具体实现方案❑设想供选择的方案❑选取合理的方案❑推荐最佳方案◼结构设计阶段,确定软件结构❑功能分解❑设计软件结构❑设计数据库❑制定测试计划❑书写文档❑审查和复审典型的总体设计过程包括下述9个步骤:1.设想供选择的方案

◼根据需求分析阶段得出的数据流图考虑各种可能的实现方案,力求从中选出最佳方案。2.选取合理的方案◼从前一步得到的一系列供选择的方案中选取若干个合理的方案。对每个合理的方案分析员都应该准备下列4份资料:❑系统流

程图;❑组成系统的物理元素清单;❑成本/效益分析;❑实现这个系统的进度计划。3.推荐最佳方案◼分析员应该综合分析对比各种合理方案的利弊,推荐一个最佳的方案,并且为推荐的方案制定详细的实现计划。4.功能分解◼首先进行结构设计,然后进行过程设计。◼结构设计确定程序由哪些模块组成,以及这些模块之间的

关系;过程设计确定每个模块的处理过程。◼结构设计是总体设计阶段的任务,过程设计是详细设计阶段的任务。5.设计软件结构◼通常程序中的一个模块完成一个适当的子功能。应该把模块组织成良好的层次系统。软件结构可以用层次图或结构图来描绘。◼如果数据流图已经细化到适当的层次,则可以直接从数据流图映射出软件

结构,这就是面向数据流的设计方法。6.设计数据库◼对于需要使用数据库的那些应用系统,软件工程师应该在需求分析阶段所确定的系统数据需求的基础上,进一步设计数据库。7.制定测试计划◼在软件开发的早期阶段考虑测试问题,能促使软件设计人员在设计时注意提高软件的可测试性。8.书写文档◼应该用正式的文档记录总

体设计的结果,在这个阶段应该完成的文档通常有下述几种:(1)系统说明;(2)用户手册;(3)测试计划;(4)详细的实现计划;(5)数据库设计结果。9.审查和复审◼最后应该对总体设计的结果进行严格的技术审查和管理复审。5.2设计原理5.2.

1模块化◼模块:是由边界元素限定的相邻程序元素的序列,而且有一个总体标识符代表它。◼模块化:就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。为什么要

模块化?◼模块化是为了使一个复杂的大型程序能被人的智力所管理,软件应该具备的惟一属性。◼如果一个大型程序仅由一个模块组成,它将很难被人所理解。模块化的根据:◼如果C(P1)>C(P2),显然E(P1)>E(P2)◼根据人类

解决一般问题的经验,C(P1+P2)>C(P1)+C(P2)◼综上所述,得到下面的不等式E(P1+P2)>E(P1)+E(P2)◼每个程序都相应地有一个最适当的模块数目M,使得系统的开发成本最小。模块化和软件成本评价一种设计

方法定义模块能力的五条标准:◼◼模块可组装性◼◼模块连续性◼模块化的作用:◼采用模块化原理可以使软件结构清晰,不仅容易设计也容易阅读和理解。◼模块化使软件容易测试和调试,因而有助于提高软件的可靠性。◼模块化能够提高软件的可修改性。◼

模块化也有助于软件开发工程的组织管理。5.2.2抽象◼抽象:现实世界中一定事物、状态或过程之间总存在着某些相似的方面(共性)。把这些相似的方面集中和概括起来,暂时忽略它们之间的差异,这就是抽象。◼抽象就是抽出事物本质特性而暂时不考虑细

节。◼“抽象是人类处理复杂问题的基本方法之一。”——GradyBoach一般抽象过程:◼处理复杂系统的惟一有效的方法是用层次的方式构造和分析它。◼一个复杂的动态系统首先可以用一些高级的抽象概念构造和理解,这些高级概念又可以用一些较低级的概念构造和理解,如

此进行下去,直至最低层次的具体元素。◼例:过程抽象、数据抽象软件工程抽象过程:◼软件工程过程的每一步都是对软件解法的抽象层次的一次精化。◼在可行性研究阶段,软件作为系统的一个完整部件;◼在需求分析期间,软件解法是使用在问题环

境内熟悉的方式描述的;◼当由总体设计向详细设计过渡时,抽象的程度也就随之减少了;◼最后,当源程序写出来以后,也就达到了抽象的最低层。5.2.3逐步求精◼逐步求精:为了能集中精力解决主要问题而尽量推迟对问题细节的考虑。逐步求精是人类解决复

杂问题时采用的基本方法,也是许多软件工程技术的基础。◼Miller法则:一个人在任何时候都只能把注意力集中在(7±2)个知识块上。例:用筛选法求100以内的素数。所谓的筛选法,就是从2到100中去掉2,3,5,7的倍数,剩下的就

是100以内的素数。◼首先按程序功能写出一个框架main(){建立2到100的数组A[],其中A[i]=i;..........................1建立2到10的素数表B[],存放2到10以内的

素数;......2若A[i]=i是B[]中任一数的倍数,则剔除A[i];............3输出A[]中所有没有被剔除的数;…..………………....4}◼上述框架中每一个加工语句都可进一步细化◼main(){/*建立2到100的数组

A[],其中A[i]=i*/………..………1for(i=2;i<=100;i++)A[i]=i;/*建立2到10的素数表B[],存放2到10以内的素数*/….2B[1]=2;B[2]=3;B[3]=5;B[4]=7;/*若A[i]=i是B[]中任

一数的倍数,则剔除A[i]*/.…..….3for(j=1;j<=4;j++)检查A[]所有数能否被B[j]整除并将其从A[]剔除;.....3.1/*输出A[]中所有没有被剔除的数*/…………………….4for(i=2;i<=100;

i++)若A[i]没有被剔除,则输出之……………………..…..4.1}◼继续对3.1和4.1细化,直到每个语句都能用程序设计语言来表示逐步求精的作用:◼它能帮助软件工程师把精力集中在与当前开发阶段最相关的那些方面上,而忽略那些对整体解决方案来说虽然是必要的,然而目前还不需要考虑的细节。

◼逐步求精方法确保每个问题都将被解决,而且每个问题都将在适当的时候被解决,但是,在任何时候一个人都不需要同时处理7个以上知识块。Wirth本人对逐步求精策略的概括说明:◼我们对付复杂问题的最重要的办法是抽象

,因此,对一个复杂的问题不应该立刻用计算机指令、数字和逻辑符号来表示,而应该用较自然的抽象语句来表示,从而得出抽象程序。◼抽象程序对抽象的数据进行某些特定的运算并用某些合适的记号(可能是自然语言)来表示。对抽象程序做进一步的分解,并进入下一个抽象层次,这样的精细化过程一直进行下去,直到程序能被计

算机接受为止。这时的程序可能是用某种高级语言或机器指令书写的。5.2.4信息隐藏和局部化◼信息隐藏:应该这样设计和确定模块,使得一个模块内包含的信息(过程和数据)对于不需要这些信息的模块来说,是不能访问的。◼局

部化:局部化的概念和信息隐藏概念是密切相关的。所谓局部化是指把一些关系密切的软件元素物理地放得彼此靠近。显然,局部化有助于实现信息隐藏。信息隐藏和局部化的作用:◼“隐藏”意味着有效的模块化可以通过定义一组独立的模

块而实现,这些独立的模块彼此间仅仅交换那些为了完成系统功能而必须交换的信息。◼使用信息隐藏原理作为模块化系统设计的标准就会带来极大好处。因为绝大多数数据和过程对于软件的其他部分而言是隐藏的,在修改期间由于疏忽而引入的错误就很少可能传播

到软件的其他部分。5.2.5模块独立模块独立:◼模块独立的概念是模块化、抽象、信息隐藏和局部化概念的直接结果。◼希望这样设计软件结构,使得每个模块完成一个相对独立的特定子功能,并且和其他模块之间的关系很简单。模块独立的重要性:◼有效的

模块化(即具有独立的模块)的软件比较容易开发出来。这是由于能够分割功能而且接口可以简化,当许多人分工合作开发同一个软件时,这个优点尤其重要。◼独立的模块比较容易测试和维护。这是因为相对说来,修改设计和程序需要的工作量

比较小,错误传播范围小,需要扩充功能时能够“插入”模块。模块独立程度的两个定性标准度量:◼耦合衡量不同模块彼此间互相依赖(连接)的紧密程度。耦合要低,即每个模块和其他模块之间的关系要简单;◼内聚衡量一个模块内部各个元素彼此结合的紧密程度

。内聚要高,每个模块完成一个相对独立的特定子功能。1.耦合◼耦合:是对一个软件结构内不同模块之间互连程度的度量。◼要求:在软件设计中应该追求尽可能松散耦合的系统。◼可以研究、测试或维护任何一个模块,而不需要对系统的其他模块有很多了

解;◼模块间联系简单,发生在一处的错误传播到整个系统的可能性就很小;◼模块间的耦合程度强烈影响系统的可理解性、可测试性、可靠性和可维护性。耦合程度的度量:(1)非直接耦合/完全独立(nodirectcoupling)◼如果两个模块中的每一个

都能独立地工作而不需要另一个模块的存在,那么它们完全独立。◼在一个软件系统中不可能所有模块之间都没有任何连接。BA无关系(2)数据耦合(datacoupling)◼如果两个模块彼此间通过参数交换信息,而且交换的信息仅仅是数据,那么这种

耦合称为数据耦合。BA通过变元传递数据评价:◼系统中至少必须存在这种耦合。一般说来,一个系统内可以只包含数据耦合。◼数据耦合是理想的目标。◼维护更容易,对一个模块的修改不会是另一个模块产生退化错误。(3)控制耦合(c

ontrolcoupling)◼如果两个模块彼此间传递的信息中有控制信息,这种耦合称为控制耦合。BAFlagf1f2fnFlag…评价:◼控制耦合往往是多余的,把模块适当分解之后通常可以用数据耦合代替它。◼被调用的模块需知道调用模块的内部结构和逻辑,降低了重用的可能性。(4)特征耦合(st

ampcoupling)◼当把整个数据结构作为参数传递而被调用的模块只需要使用其中一部分数据元素时,就出现了特征耦合。评价:◼被调用的模块可使用的数据多于它确实需要的数据,这将导致对数据的访问失去控制,从而给计算机犯罪提供了机会。

◼无论何时把指针作为参数进行传递,都应该仔细检查该耦合。(5)公共环境耦合(commoncoupling)◼当两个或多个模块通过一个公共数据环境相互作用时,它们之间的耦合称为公共环境耦合。公共环境可以是全程变量、共享的通信区、内存的公共覆盖区、任何存储介质上的文件、物理设备等等。公共环境耦合的

类型:◼一个模块往公共环境送数据,另一个模块从公共环境取数据。数据耦合的一种形式,是比较松散的耦合。◼两个模块都既往公共环境送数据又从里面取数据,这种耦合比较紧密,介于数据耦合和控制耦合之间。AABBCommon公共数据区Common公共数据区(a)松散的公共环境耦合(b)紧密的公共环境耦

合例:while(global_bariable==0){if(argument_xyz>25)module_3();elsemodule_4();}评价:◼与结构化编程矛盾,生成的代码完全不可读。◼如果在一个模块中对一个全局变量的声明进行修改,必须修

改能够访问该全局变量的每一个模块。◼公共环境耦合的模块难于重用,必须提供一个全局变量的清单。◼即使模块本身不改变,它和产品中其他模块之间公共环境耦合的实例数也会变化非常大。◼潜在危险很大。模块暴露出必需要更多的数据,难以控制数据存取,而且会导致计算机犯罪。◼有些情况下

公共环境耦合更好。(6)内容耦合(contentcoupling)◼最高程度的耦合是内容耦合。如果出现下列情况之一,两个模块间就发生了内容耦合:❑一个模块访问另一个模块的内部数据;❑一个模块不通过正常入口转到另一个模块的内部;❑两个模块有一部分程序代码重叠;❑一个模块有多个入口。AABBentry

1……entry2……(a)进入另一模块内部(b)模块代码重叠(c)多入口模块◼耦合是影响软件复杂程度的一个重要因素。◼应该采取下述设计原则:尽量使用数据耦合,少用控制耦合和特征耦合,限制公共环境耦合的范围,完全

不用内容耦合。2.内聚◼内聚:标志一个模块内各个元素彼此结合的紧密程度,它是信息隐藏和局部化概念的自然扩展。简单地说,理想内聚的模块只做一件事情。◼要求:设计时应该力求做到高内聚,通常中等程度的内聚也是可以采用的,而且效果和高内聚相差不多;但是,低内聚不要使用。◼内聚和耦合是密切相

关的,模块内的高内聚往往意味着模块间的松耦合。实践表明内聚更重要,应该把更多注意力集中到提高模块的内聚程度上。内聚程度的度量:(1)偶然内聚(coincidentalcohesion)◼如果一个模块完成一组任务,这些任务彼此间即使有关系,关系也是很松散的,就叫

做偶然内聚。MA=B+CGETCHERIF评价:◼模块内各元素之间没有实质性联系,很可能在一种应用场合需要修改这个模块,在另一种应用场合又不允许这种修改,从而陷入困境;◼可理解性差,可维护性产生退化;◼模块是不可重用的。解决方案:◼将模块分成更小的模块

,每个小模块执行一个操作。(2)逻辑内聚(logicalcohesion)◼如果一个模块完成的任务在逻辑上属于相同或相似的一类,则称为逻辑内聚。读入分数平均/最高?计算平均分计算最高分输出结果new_operatio

nfunction_code=7;new_operation(function_code,dummy1,dummy2,dummy3);//dummy1、dummy2和dummy3是伪变量,//如果function_code=7则不使用它们评价:◼接口难以理解,造成整体上不

易理解;◼完成多个操作的代码互相纠缠在一起,即使局部功能的修改有时也会影响全局,导致严重的维护问题;◼难以重用。解决方案:◼模块分解。读入分数平均/最高?计算平均分计算最高分输出结果读入分数计算平均分输出结果模块A读入分数计算最高

分输出结果模块B(3)时间内聚(temporalcohesion)◼如果一个模块包含的任务必须在同一段时间内执行,就叫时间内聚。执行初始化打开旧主文件、新主文件、事务文件和打印文件;初始化销售地区表;读第一条事务记录和第一条旧主文件记录;

评价:◼时间关系在一定程度上反映了程序某些实质,所以时间内聚比逻辑内聚好一些。◼模块内操作之间的关系很弱,与其他模块的操作却有很强的关联。◼时间内聚的模块不太可能重用。(4)过程内聚(proceduralcohesion)◼如果

一个模块内的处理元素是相关的,而且必须以特定次序执行,则称为过程内聚。◼使用程序流程图作为工具设计软件时,常常通过研究流程图确定模块的划分,这样得到的往往是过程内聚的模块。评价:◼比时间内聚好,至少操作之间是

过程关联的。◼仍是弱连接,不太可能重用模块。解决方案:◼分割为单独的模块,每个模块执行一个操作。(5)通信内聚(communicationalcohesion)◼如果模块中所有元素都使用同一个输入数据和(或)产生同一个输出数据,则称为通信内聚。即在同一个数据结构上操

作。评价:◼模块中各操作紧密相连,比过程内聚更好。◼不能重用。解决方案:◼分成多个模块,每个模块执行一个操作。(6)顺序内聚(sequentialcohesion)◼如果一个模块内的处理元素和同一个功能密切相关,而且这些处

理必须顺序执行,则称为顺序内聚。评价:◼根据数据流图划分模块时,通常得到顺序内聚的模块,这种模块彼此间的连接往往比较简单。(7)功能内聚(functionalcohesion)◼如果模块内所有处理元素

属于一个整体,完成一个单一的功能,则称为功能内聚。功能内聚是最高程度的内聚。评价:◼模块可重用,应尽可能重用;◼可隔离错误,维护更容易;◼扩充产品功能时更容易。七种内聚的优劣评分结果:◼高内聚:功能内聚10分顺序内聚9分◼中内聚:通信内聚7分过程内聚5分◼低内聚:时间内聚3分逻辑内聚1分偶然内聚0

分◼设计时力争做到高内聚,并且能够辨认出低内聚的模块。5.3启发规则1.改进软件结构提高模块独立性◼通过模块分解或合并,降低耦合提高内聚。◼两个方面:❑模块功能完善化。一个完整的模块包含:◼执行规定的功能的部分◼出错处理的部分◼返回一个“结束标志”

❑消除重复功能,改善软件结构。◼完全相似◼局部相似XR1R2完全相似YXYR1+R2完全合并XR1R2局部相似YXR1R2方案一YX+R1R2方案二YX+R1方案三Y+R22.模块规模应该适中◼经验表

明,一个模块的规模不应过大,最好能写在一页纸内。通常规定50~100行语句,最多不超过500行。数字只能作为参考,根本问题是要保证模块的独立性。◼过大的模块往往是由于分解不充分,但是进一步分解必须符合问题结构,一般说来,分解后不应该降低模块独立性。◼过小的模块开销大于有效操作,而且模

块数目过多将使系统接口复杂。3.深度、宽度、扇出和扇入都应适当◼深度:软件结构中控制的层数,它往往能粗略地标志一个系统的大小和复杂程度。◼宽度:软件结构内同一个层次上的模块总数的最大值。◼扇出:一个模块直接控制(调用)的模块数目。◼扇入:有多少个上

级模块直接调用它。宽度=9深度=5扇入=2扇出=1QQ1QQ2Q3非公共模块扇入过大PP1PP2扇出过大4.模块的作用域应该在控制域之内◼模块的作用域:定义为受该模块内一个判定影响的所有模块的集合。◼模块的控制域:是

这个模块本身以及所有直接或间接从属于它的模块的集合。◼在一个设计得很好的系统中,所有受判定影响的模块应该都从属于做出判定的那个模块,最好局限于做出判定的那个模块本身及它的直属下级模块。AMGCBDFEA的控制域A的作用域违反规则的情况解决方案:◼把模块A中的判定移到模块M中;◼

把模块G移到模块A下面,作为他的下级模块。A-M+GCBDFEA的判定上移AMGCBDFE5.力争降低模块接口的复杂程度◼模块接口复杂是软件发生错误的一个主要原因。应该仔细设计模块接口,使得信息传递简单并且和模块的功能一致。例:解一元二次方程的函数◼QUAD_ROOT

(TBL,X)❑其中数组TBL传送方程的系数❑数组X送回求得的根◼QUAD_ROOT(A,B,C,ROOT1,ROOT2)6.设计单入口单出口的模块◼警告软件工程师不要使模块间出现内容耦合。当从顶部进入模块并且从底部退出来时,软件是比较容易理解的,因此也是比较容易维护的。7

.模块功能应该可以预测◼模块的功能应该能够预测,但也要防止模块功能过分局限。◼功能可预测:如果一个模块可以当做一个黑盒子,只要输入的数据相同就产生同样的输出,这个模块的功能就是可以预测的。5.4描绘软件结

构的图形工具5.4.1层次图和HIPO图1.层次图(H图)◼层次图用来描绘软件的层次结构。很适于在自顶向下设计软件的过程中使用。层次图和层次方框图的区别:层次图层次方框图作用描绘软件结构描绘数据结构矩形框模块数据元素连线调用关系组

成关系正文加工系统的层次图2.HIPO图◼HIPO图是美国IBM公司发明的“层次图+输入/处理/输出图”的英文缩写。◼为了能使HIPO图具有可追踪性,在H图(层次图)里除了最顶层的方框之外,每个方框都加了编号。◼和H图中每个

方框相对应,应该有一张IPO图描绘这个方框代表的模块的处理过程。模块在H图中的编号便于追踪了解这个模块在软件结构中的位置。5.4.2结构图◼Yourdon提出的结构图是进行软件结构设计的另一个有力工具。结构图和层次图类似,也是描绘软件结构的图形工

具。基本符号:◼方框代表一个模块;◼方框之间的直线表示模块的调用关系;◼尾部是空心圆箭头表示传递的是数据;◼尾部实心圆箭头表示传递的是控制信息。附加符号:◼选择调用:判定为真时调用A,为假时调用B。◼循环调用:模块M循环调用模块A、B、C。注意:◼层次图和结构图并不严格表示模块的

调用次序,多数人习惯按调用次序从左到右画模块;◼层次图和结构图并不指明何时调用下层模块;◼层次图和结构图只表明一个模块调用那些模块,没有表示模块内还有没有其他成分;◼通常用层次图作为描绘软件结构的文档;◼由层次图导出结构图的过程,可以作为检查设计正确性和评价

模块独立性的好方法。5.5面向数据流的设计方法◼面向数据流的设计方法定义了一些不同的“映射”,利用这些映射可以把数据流图变换成软件结构。◼因为任何软件系统都可以用数据流图表示,所以面向数据流的设计方法理论上可以设计任何软件的结构。通常所说的结构化设

计方法(简称SD方法),也就是基于数据流的设计方法。5.5.1概念◼面向数据流的设计方法把信息流映射成软件结构,信息流的类型决定了映射的方法。◼信息流有两种类型:❑变换流❑事务流1.变换流◼信息沿输入通路进入系统,同时由外部形式变换成内部形式,进入系统的信息通过

变换中心,经加工处理以后再沿输出通路变换成外部形式离开软件系统。2.事务流◼数据沿输入通路到达一个处理T,T根据输入数据的类型在若干个动作序列中选出一个来执行。处理T称为事务中心,它完成下述任务:❑接收输入数据;❑分析每个事

务以确定它的类型;❑根据事务类型选取一条活动通路。3.设计过程5.5.2变换分析◼变换分析是一系列设计步骤的总称,经过这些步骤把具有变换流特点的数据流图按预先确定的模式映射成软件结构。设计步骤:(1)复查基本系统模型◼确保系统的输入数据和输出数据符合实际

。(2)复查并精化数据流图◼对需求分析阶段得出的数据流图认真复查,并且在必要时进行精化。◼不仅要确保数据流图给出了目标系统的正确的逻辑模型,而且应该使数据流图中每个处理都代表一个规模适中相对独立的子功能。(3)确定数据流

图具有变换特性还是事务特性◼一个系统中的所有信息流都可以认为是变换流,但是,当遇到有明显事务特性的信息流时,建议采用事务分析方法进行设计。确定数据流的全局特性和局部特性。(4)确定输入流和输出流的边界,从而孤立出变换中心◼输入流和输出流的边界和对它们的解释有关,不同

设计人员可能会在流内选取稍微不同的点作为边界的位置。(5)完成“第一级分解”。◼位于软件结构最顶层的控制模块Cm协调下述从属的控制功能:❑输入信息处理控制模块Ca,协调对所有输入数据的接收;❑变换中心控制模块Ct,管理对内部形式的数据的所有操作;❑输出信息处理

控制模块Ce,协调输出信息的产生过程。第一级分解方法(6)完成“第二级分解”◼处理映射成软件结构中一个适当的模块。完成第二级分解的方法是:❑从变换中心的边界开始沿着输入通路向外移动,把输入通路中每个处理映射成软件结构中Ca控制下的一个

低层模块;❑然后沿输出通路向外移动,把输出通路中每个处理映射成直接或间接受模块Ce控制的一个低层模块;❑最后把变换中心内的每个处理映射成受Ct控制的一个模块。第二级分解方法ADBCPQRWUVXCmCaRCBPQCtDACeVWXU(7)使用设计度量和启发式规则

对第一次分割得到的软件结构进一步精化◼为了产生合理的分解,得到尽可能高的内聚、尽可能松散的耦合,为了得到一个易于实现、易于测试和易于维护的软件结构,应该对初步分割得到的模块进行再分解或合并。5.5.3事务分析◼虽然在任何情况下都可以使用变换分析方法设计软件结构,但是在数据流

具有明显的事务特点时,也就是有一个明显的“发射中心”(事务中心)时,还是以采用事务分析方法为宜。◼事务分析的设计步骤和变换分析的设计步骤大部分相同或类似,主要差别仅在于由数据流图到软件结构的映射方法不同:❑由事务流映射成的软件结构包括一个接收分支和一个发送分支;

❑映射出接收分支结构的方法和变换分析映射出输入结构的方法很相像,即从事务中心的边界开始,把沿着接收流通路的处理映射成模块;❑发送分支的结构包含一个调度模块,它控制下层的所有活动模块;然后把数据流图中的每个活动流通路映射成与它的流特征相对应的结构。MNHLDEJGF

KI接收通路A通路B通路C通路总控MA通路LDGEF调度NC通路B通路IHKJ例1:◼设计一个产品,它将一个文件名作为输入,并返回文件中的字数。文件名文件名读取文件名字数验证文件名格式化字数有效的文件名统计字数字数格式化的字数显示

字数输入流边界输出流边界第一级分解字数统计程序输入文件名统计字数输出字数第二级分解字数统计程序输入文件名统计字数读取文件名验证文件名格式化字数显示字数输出字数精化字数统计程序输入文件名统计字数读取文件名验

证文件名格式化字数显示字数输出字数例2:汽车数字仪表板◼通过模数转换实现传感器和微处理机接口;◼在发光二极管面板上显示数据;◼指示每小时英里数(mph),行驶的里程,每加仑油行驶的英里数(mpg)等等;◼指示加速或减速;◼超速警告:如果车

速超过55英里/小时,则发出超速警告铃声。第一级分解第二级分解精化例3:自动柜员机◼顾客插入磁卡,输入密码,然后执行动作,包括向支票、存折或信用卡账户存款,提款或查询余额等。◼设计上分成两部分:分析器和调度器。分析器确定事务类型并将信息送到分配器,由调度器进行事务处理。查询事务确定事务类型编

辑事务1编辑事务2有效事务编辑事务5编辑事务3接收边界发送边界更新文件1更新文件5更新文件3更新文件4更新文件2编辑事务4写入审计单有效事务有效事务有效事务有效事务存款取款转账修改密码审计信息ATM处理事务总控分析器更新文件

5更新文件1更新文件2更新文件3更新文件4调度器编辑事务1写入审计单编辑事务4编辑事务5编辑事务3编辑事务2查询转账修改密码取款存款ATM处理事务总控分析器查询更新文件分配器编辑事务写入审计单转账修改密码取款存款例4:一个公司的销

售管理系统判别输入定货输入进货修改库存统计分析处理定货记录定单开提货发票读入数据生成统计表开进货票据销售管理系统读入数据键盘输入开提货发票判别处理定货输入进货进货统计定货输入定货修改库存开进货票据记录定单统计分析生成统计表总结:◼一般说来,如果数据流不具有显著的事务特

点,最好使用变换分析;反之,如果具有明显的事务中心,则应该采用事务分析技术。◼机械地遵循变换分析或事务分析的映射规则,可能会得到一些不必要的控制模块,如果它们确实用处不大,那么可以而且应该把它们合并。◼如果一个控制模块功能过分复杂,则应该分解为两个或多个控制模块,

或者增加中间层次的控制模块。5.5.4设计优化◼设计优化应该力求做到在有效的模块化的前提下使用最少量的模块,以及在能够满足信息要求的前提下使用最简单的数据结构。◼对于时间是决定性因素的应用场合,可能有必要在详细设计阶段,也可能在编写程序的过程中进行优化。◼软件开发人员应该认识到

,程序中相对说比较小的部分(典型地,10%~20%),通常占用全部处理时间的大部分(50%~80%)。对时间起决定性作用的软件进行优化:◼在不考虑时间因素的前提下开发并精化软件结构;◼在详细设计阶段选出最耗费时间的那些模块,仔细地设计它们的处理过程,以求提高效率;

◼使用高级程序设计语言编写程序;◼在软件中孤立出那些大量占用处理机资源的模块;◼必要时重新设计或用依赖于机器的语言重写上述大量占用资源的模块的代码,以求提高效率。

精品优选
精品优选
该用户很懒,什么也没有留下。
  • 文档 34925
  • 被下载 0
  • 被收藏 0
相关资源
广告代码123
若发现您的权益受到侵害,请立即联系客服,我们会尽快为您处理。侵权客服QQ:395972555 (支持时间:9:00-21:00) 公众号
Powered by 太赞文库
×
确认删除?