您好,欢迎访问三七文档
第2章软件设计基本概念2.1设计过程2.2设计原理2.3启发规则软件设计宣言: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一般抽象过程:处理复杂系统的惟一有效的方法是用层次的方式构造和分析它。一个复杂的动态系统首先可以用一些高级的抽象概念构造和理解,这些高级概念又可以用一些较低级的概念构造和理解,如此进行下去,直至最低层次的具体元素。例:过程抽象、数据抽象开(行为抽象)+门(数据抽象)19形体衣着性格抽象抽象例子外表软件工程抽象过程:软件工程过程的每一步都是对软件解法的抽象层次的一次精化。在可行性研究阶段,软件作为系统的一个完整部件;在需求分析期间,软件解法是使用在问题环境内熟悉的方式描述的;当由总体设计向详细设计过渡时,抽象的程度也就随之减少了;最后,当源程序写出来以后,也就达到了抽象的最低层。5.2.3逐步求精逐步求精:为了能集中精力解决主要问题而尽量推迟对问题细节的考虑。逐步求精是人类解决复杂问题时采用的基本方法,也是许多软件工程技术的基础。Miller法则:一个人在任何时候都只能把注意力集中在(7±2)个知识块上。22逐步求精外表形体衣着性格头发脸形领带抽象逐步求精的例子例:用筛选法求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)控制耦合(controlcoupling)如果两个模块彼此间传递的信息中有控制信息,这种耦合称为控制耦合。BAFlagf1f2fnFlag…评价:控制耦合往往是多余的,把模块适当分解之后通常可以用数据耦合代替它。被调用的模块需知道调用模块的内部结构和逻辑,降低了重用的可能性。(4)特征耦合(stampcoupling)当把整个数据结构作为参数传递而被调用的模块只需要使用其中一部分数据元素时,就出现了特征耦合。评价:被调用的模块可使用的数据多于它确实需要的数据,这将导致对数据的访问失去控制,从而给计算机犯罪提供了机会。无论何时把指针作为参数进行传递,都应该仔细检查该耦合。(5)公共环境耦合(commoncoupling)当两个或多个模块通过一个公共数据环境相互作用时,它们之间的耦合称为公共环境耦合。公共环境可以是全程变量、共享的通信区、内存的公共覆盖区、任何存储介质上的文件、物理设备等等。公共环境耦合的类型:一个模块往公共环境送数据,另一个模块从公共环境取数据。数据耦合的一种形式,是比较松散的耦合。两个模块都既往公共环境送数据又从里面取数据,这种耦合比较紧密,介于数据耦合和控制耦合之间。AABBCommon公共数据区Common公共数据区(a)松散的公共环境耦合(b)紧密的公共环境耦合例:while(gl
本文标题:软件设计基本概念
链接地址:https://www.777doc.com/doc-4728610 .html