2020年1月29日星期三1西北师大物电学院授课教师:宋海声第五章总体设计§1软件概要设计概述一、概要设计基本任务(P81—P83,9条)1.设计软件系统结构(简称软件结构)为了实现目标系统,最终必须设计出组成这个系统的所有程序和数据库(文件),对于程序,则首先进行结构设计,具体方法如下:2020年1月29日星期三2西北师大物电学院授课教师:宋海声第五章总体设计(1)采用某种设计方法,将一个复杂的系统按功能划分成模块。(2)确定每个模块的功能。(3)确定模块之间的调用关系。(4)确定模块之间的接口,即模块之间传递的信息。(5)评价模块结构的质量。2020年1月29日星期三3西北师大物电学院授课教师:宋海声第五章总体设计从以上内容看,软件结构的设计是以模块为基础的,在需求分析阶段,通过某种分析方法把系统分解成层次结构。在设计阶段,以需求分析的结果为依据,从实现的角度划分模块,并组成模块的层次结构。2020年1月29日星期三4西北师大物电学院授课教师:宋海声第五章总体设计软件结构的设计是概要设计关键的一步,直接影响到详细设计与编码的工作。软件系统的质量及一些整体特性都在软件结构的设计中决定。因此,应由经验丰富的软件人员担任,采用一定的设计方法,选取合理的设计方案。2020年1月29日星期三5西北师大物电学院授课教师:宋海声第五章总体设计2.数据结构及数据库设计对于大型数据处理的软件系统,除了系统结构设计外,数据结构与数据库设计也是重要的。1)数据结构的设计逐步细化的方法也适用于数据结构的设计。在需求分析阶段,可通过数据字典对数据的组成、操作约束和数据之间的关系等方面进行描述,确定数据的结构特性,在概要设计阶段要加以细化,详细设计则规定具体的实现细节。2020年1月29日星期三6西北师大物电学院授课教师:宋海声第五章总体设计2)数据库的设计指数据存储文件的设计,(1)概念设计。在数据分析的基础上,从用户角度采用自底向上的方法进行视图设计。一般用ER模型来表示数据模型,这是一个概念模型。ER模型既是设计数据库的基础,也是设计数据结构的基础。2020年1月29日星期三7西北师大物电学院授课教师:宋海声第五章总体设计(2)逻辑设计。ER模型是独立于数据库管理系统(DBMS)的,要结合具体的DBMS特征来建立数据库的逻辑结构。对于关系型的DBMS来说,将概念结构转换为数据模式、子模式并进行规范,要给出数据结构的定义,即定义所含的数据项、类型、长度及它们之间的层次或相互关系的表格等。2020年1月29日星期三8西北师大物电学院授课教师:宋海声第五章总体设计(3)物理设计。对于不同的DBMS,物理环境不同,提供的存储结构与存取方法各不相同。物理设计就是设计数据模式的一些物理细节,如数据项存储要求、存取方式和索引的建立等。2020年1月29日星期三9西北师大物电学院授课教师:宋海声第五章总体设计数据库技术是一项专门的技术,本书不作详细的讨论。但开发人员应注意到,在大型数据处理系统的功能分析与设计中,同时要进行数据分析与数据设计。数据库的“概念设计”与“逻辑设计”分别对应于系统开发中的“需求分析”与“概要设计”,而数据库的“物理设计”与模块的“详细设计”相对应。2020年1月29日星期三10西北师大物电学院授课教师:宋海声第五章总体设计3.(1)概要设计说明书。(2)数据库设计说明书:主要给出所使用的DBMS简介,数据库的概念模型、逻辑设计和结果。2020年1月29日星期三11西北师大物电学院授课教师:宋海声第五章总体设计(3)用户手册:对需求分析阶段编写的用户手册进行补充。(4)修订测试计划:对测试策略、方法和步骤提出明确要求。4.在该阶段,对设计部分是否完整地实现了需求中规定的功能、性能等要求,设计方案的可行性、关键的处理及内外部接口定义正确性、有效性以及各部分之间的一致性等,都一一进行评审。2020年1月29日星期三12西北师大物电学院授课教师:宋海声第五章总体设计二、概要设计说明书是概要设计阶段结束时提交的技术文档。按国标GB8576-88的《计算机软件产品开发文件编制指南》规定,软件设计文档可分为“概要设计说明书”、“详细设计说明书”和“数据库设计说明书”。2020年1月29日星期三13西北师大物电学院授课教师:宋海声第五章总体设计(1)引言:编写目的,背景,定义,参考资料。(2)总体设计:需求规定,运行环境,基本设计概念和处理流程,结构。(3)接口设计:用户接口,外部接口,内部接口(4)运行设计:运行模块组合,运行控制,运行时间。2020年1月29日星期三14西北师大物电学院授课教师:宋海声第五章总体设计(5)系统数据结构设计:逻辑结构设计,物理结构设计,数据结构与程序的关系。(6)系统出错处理设计:出错信息,补救措施,系统恢复设计。2020年1月29日星期三15西北师大物电学院授课教师:宋海声第五章总体设计§2一、模块化的概念在程序设计技术中就出现了。何为模块?模块在程序中是数据说明、可执行语句等程序对象的集合,或者是单独命名和编址的元素,如高级语言中的过程、函数和子程序等。在软件的体系结构中,模块是可组合、分解和更换的单元。模块具有以下几2020年1月29日星期三16西北师大物电学院授课教师:宋海声第五章总体设计(1)接口:指模块的输入与输出。(2)功能:指模块实现什么功能。(3)逻辑:描述内部如何实现要求的功能及所需的数据。(4)状态:指该模块的运行环境,即模块的调用与被调用关系。2020年1月29日星期三17西北师大物电学院授课教师:宋海声第五章总体设计功能、状态与接口反映模块的外部特性,逻辑反映它的内部特性。模块化是指解决一个复杂问题时自顶向下逐层把软件系统划分成若干模块的过程。每个模块完成一个特定的子功能,所有的模块按某种方法组装起来,成为一个整体,完成整个系统所要求的功能。2020年1月29日星期三18西北师大物电学院授课教师:宋海声第五章总体设计在面向对象设计中,模块和模块化的概念将进一步扩充(详见第11~12章)。模块化是软件解决复杂问题所具备的手段,为了说明这一点,可用问题的复杂性和工作量的关系2020年1月29日星期三19西北师大物电学院授课教师:宋海声第五章总体设计设问题x,表示它的复杂性函数为C(x),解决它所需的工作量函数为E(x)。对于问题P1和P2;如果C(P1)>C(P2)即P1比P2复杂,那么E(P1)>E(P2)即问题越复杂,所需要的工作量越大。2020年1月29日星期三20西北师大物电学院授课教师:宋海声第五章总体设计根据解决一般问题的经验,规律为:C(P1+P2)>C(P1)+C(P2)即一个问题由两个问题组合而成的复杂度大于分别考虑每个问题的复杂度之和。这样,可以推出:E(P1+P2)>E(P1)+E(P2)2020年1月29日星期三21西北师大物电学院授课教师:宋海声第五章总体设计由此可知,开发一个大而复杂的软件系统,将它进行适当的分解,不但可降低其复杂性,还可减少开发工作量,从而降低开发成本,提高软件生产率,这就是模块化的依据。2020年1月29日星期三22西北师大物电学院授课教师:宋海声第五章总体设计但是否将系统无限制分割,最后开发软件的工作量就会趋于零?事实上模块划分越多,块内的工作量减少,但模块之间接口的工作量增加了,如图5.1所示(P84)。从图看出,存在着一个使软件开发成本最小区域的模块数M,虽然目前还不能确定M的准确数值,但在划分模块时,避免数目过多或过少,一个模块的规模应当取决于它的功能和用途。同时,应减少接口的代价,提高模块的独立性。2020年1月29日星期三23西北师大物电学院授课教师:宋海声第五章总体设计二、抽象是认识复杂现象过程中使用的思维工具,即抽出事物本质的共同特性而暂不考虑它的细节,不考虑其他因素。抽象的概念被广泛应用于计算机软件领域,在软件工程学中更是如此。软件工程实施中的每一步都可以看作是对软件抽象层次的一次细化。2020年1月29日星期三24西北师大物电学院授课教师:宋海声第五章总体设计在系统定义阶段,软件可作为整个计算机系统的一个元素来对待;在软件需求分析阶段,软件的解决方案是使用问题环境中的术语来描述;从概要设计到详细设计阶段,提象的层次逐步降低,将面向问题的术语与面向实现的术语结合起来描述解决方法,直到产生源程序时到达最低的抽象层次。这是软件工程整个过程的抽象层次。2020年1月29日星期三25西北师大物电学院授课教师:宋海声第五章总体设计具体到软件设计阶段,又有不同的抽象层次,在进行软件设计时,抽象与逐步求精、模块化密切相关,可帮助定义软件结构中模块的实体,由抽象到具体地分析和构造出软件的层2020年1月29日星期三26西北师大物电学院授课教师:宋海声第五章总体设计三、通过抽象,可以确定组成软件的过程实体。通过信息隐蔽,可以定义和实施对模块的过程细节和局部数据结构的存取限制。所谓信息隐蔽,是指在设计和确定模块时,使得一个模块内包含的信息(过程或数据),对于不需要这些信息的其他模块来说,是不能访问的;“隐蔽”的意思是,有效的模块化通过定义一组相互独立的模块来实现,这些独立的模块彼此之间仅仅交换那些为了完成系统功能所必需的信息,而将那些自身的实现细节与数据“隐藏”起来。2020年1月29日星期三27西北师大物电学院授课教师:宋海声第五章总体设计一个软件系统在整个生存期中要经过多次修改,信息隐蔽为软件系统的修改、测试及以后的维护都带来好处。因此,在划分模块时要采取措施,如采用局部数据结构,使得大多数过程(即实现细节)和数据对软件的其他部分是隐藏的,这样,修改软件时偶然引入的错误所造成的影响只局限在一个或少量几个模块内2020年1月29日星期三28西北师大物电学院授课教师:宋海声第五章总体设计四、为了降低软件系统的复杂性,提高可理解性、可维护性,必须把系统划分成为多个模块,但模块不能任意划分,应尽量保持其独立性。模块独立性指每个模块只完成系统要求的独立的子功能,并且与其他模块的联系最少且接口简单。模块独立性概念是模块化、抽象及信息隐蔽这些软件工程基本原理的直接产物。只有符合和遵守这些原则才能得到高度独立的模块。良好的模块独立性能使开发的软件具有较高的质量。2020年1月29日星期三29西北师大物电学院授课教师:宋海声第五章总体设计为什么模块的独立性很重要呢?主要有两条理由:第一,有效的模块化(即具有独立的模块)的软件比较容易开发出来。这是由于能够分割功能而且接口可以简化,当许多人分工合作开发同一个软件时,这个优点尤其重要。第二,独立的模块比较容易测试和维护。这是因为相对说来,修改设计和程序需要的工作量比较小,错误传播范围小,需要扩充功能时能够“插入”模块。总之,模块独立是好设计的关键,而设计又是决定软件质量的关键环节。2020年1月29日星期三30西北师大物电学院授课教师:宋海声第五章总体设计由于模块独立性强,信息隐藏性能好,并完成独立的功能,且它的可理解性、可维护性及可测试性好,必然导致软件的可靠性高。另外,接口简单、功能独立的模块易开发,且可并行工作,有效地提高了软件的生产率。如何衡量软件的独立性呢?根据模块的外部特征和内部特征,提出了两个定性的度量标准——耦合性和内聚性。2020年1月29日星期三31西北师大物电学院授课教师:宋海声第五章总体设计1.耦合性(Coupling)耦合性也称块间联系,指软件系统结构中各模块间相互联系紧密程度的一种度量。模块之间联系越紧密,其耦合性就越强,模块的独立性则越差。模块间耦合高低取决于模块间接口的复杂性、调用的方式及传递的信息。2020年1月29日星期三32西北师大物电学院授课教师:宋海声第五章总体设计无直接耦合数据耦合特征耦合控制耦合公共耦合内容耦合低偶合性(1)无直接耦合:指两个模块之间没有直接的关系,它们分别从属于不同模块的控制与调用,它们之间不传递任何信息。因此,模块间的这种耦合性最弱,模块独立性最高。2020年1月29日星期三33西北师大物电学院授课教师:宋海声第五章总体设计(2)数据耦