欢迎来到天天文库
浏览记录
ID:27660005
大小:217.34 KB
页数:34页
时间:2018-12-05
《总体设计systemdesig》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第四章总体设计(SystemDesign)开始考虑“How”,但仍属高层设计(确定黑盒关系)§1.过程1、确定最佳方案:从DFD出发进行任务分解,不同的划分方法即对应不同的方案。每个合理的方案应配备下列4份资料:⑴系统流程图⑵组成系统的物理元素清单⑶成本/效益分析⑷进度计划选择最佳方案并制定详细的实现计划(主要技术详见第十三章)§1.过程2、结构设计——模块化思想:将DFD细化,至每个子功能都明白易懂;每个模块完成一个子功能;每层模块合成一个高一级的功能。主要工具有SystemDesignHierarchy及HIPO图等。3、数据库设计(略)5、文档、审查4、测试计划(详见第七章)
2、§2.模块化原理(Modularization)1、原理:经验1:E(P1+P2)>E(P1)+E(P2)经验2:P.58图4.1成本成本/模块最小成本区接口成本软件总成本模块数目§2.模块化原理2、抽象(Abstraction):忽略细节,分层理解问题,自顶向下层层加细。例:开发一个CAD软件,实现一个二维绘图系统的全部功能,供低级计算机辅助设计使用。抽象层次I:用问题所处环境的术语来描述这个软件。该软件包括一个计算机绘图界面,向绘图员显示图形,以及一个数字化仪界面,用以代替绘图板和丁字尺。所有直线、折线、矩形、圆及曲线的描画、所有的几何计算、所有的剖面图和辅助视图都可以用这个CA
3、D软件实现……。§2.模块化原理抽象层次II:任务需求的描述。列出“What”而不是“How”。CADSOFTWARETASKS:userinteractiontask;2-Ddrawingcreationtask;graphicsdisplaytask;drawingfilemanagementtask;END§2.模块化原理抽象层次III:程序过程表示。以2-D绘图生成任务为例:PROCEDURE2-DdrawingcreationREPEATUNTILE(drawingcreationtaskterminates)DOWHILE(digitizerinteractionocc
4、urs)Digitizerinterfacetask;DETERMINEdrawingrequestCASELine:linedrawingtask;Rectangle:rectangledrawingtask;Circle:circledrawingtask;……END;DOWHILE(keyboardinteractionoccurs)keyboardinteractiontask;PROCESSanalysis/computationCASEView:auxiliaryviewtask;Section:crosssectioningtask;……END;……ENDREPETITI
5、ON;ENDPROCEDURE.§2.模块化原理3、信息隐蔽(Informationhiding)Theclientsofamoduleknowaboutitsservicesonlythroughitsinterface;theimplementationishiddenfromthem(hencemaychangewithoutaffectingtheclients).4、模块独立性(Moduleindependence)好设计的关键:每个模块完成一个相对独立的子功能,并且与其它模块间的接口简单。在这个抽象层次上,给出了初步的过程表示,所用的术语都已面向软件,而且模块化的工作已经开
6、始显露。§2.模块化原理⑴耦合(Coupling)GreatdealofdependenceIndependentHighlycoupledLooselycoupledUncoupled独立性的度量:耦合(Coupling)&内聚(Cohesion)(Yourdon&Constantine,1978)§2.模块化原理例1:A访问C的内部数据或不通过正常入口而转入C的内部。……ABCDA:……………………gotoC1……………………C:……………………C1:…………独立性由弱到强排列为:内容耦合(ContentCoupling):Onemodulemodifiesanother.§
7、2.模块化原理例2:部分代码重叠(常出现在汇编程序中)BA例3:一个模块有多个入口(功能)A:………………………………entry1:………………………………entry2:………………………………Theleastdesirable§2.模块化原理公共耦合(Commoncoupling):Dataareaccessiblefromacommondatastore.Global:V1V2A:……………………A1=V1+V2……………………B:……
此文档下载收益归作者所有