《第4章 概要设计.ppt》由会员分享,可在线阅读,更多相关《第4章 概要设计.ppt(41页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、PPT模板下载:/moban/ 行业PPT模板:/hangye/ 节日PPT模板:/jieri/ PPT素材下载:/sucai/PPT背景图片:/beijing/ PPT图表下载:/tubiao/ 优秀PPT下载:/xiazai/ PPT教程: /powerpoint/ Word教程: /word/ Excel教程:/excel/ 资料下载:/ziliao/ PPT课件下载:/kejian/ 范文下载:/fanwen/ 试卷下载:/shiti/ 教案下载:/jiaoan/ 字体下载:/ziti/ 第4章 概要设计2目录页概要设计第4章本章本章要点要点n 掌握软件设计的概念与原则;n 理解软件设
2、计的任务;n 掌握概要设计的内容与步骤;n 掌握结构化设计方法;n 了解概要设计说明书的内容。3目录页4.1软件设计概述第4章软件设计是软件工程的重要阶段,是一个将软件需求转换为软件表示的过程。软件设计的软件设计是软件工程的重要阶段,是一个将软件需求转换为软件表示的过程。软件设计的基本目标是用比较抽象概括的方式确定目标系统如何完成预定的任务,即确定系统的物理模型,基本目标是用比较抽象概括的方式确定目标系统如何完成预定的任务,即确定系统的物理模型,解决软件系统解决软件系统“怎么做怎么做”的问题。的问题。软件设计不同于程序设计,程序设计是软件设计的编码实现过程。软件设计的重要性有以软件设计不同于程
3、序设计,程序设计是软件设计的编码实现过程。软件设计的重要性有以下几点:下几点:(1)软件开发阶段(设计、编码、测试)占据软件项目开发总成本绝大部分,是在软件)软件开发阶段(设计、编码、测试)占据软件项目开发总成本绝大部分,是在软件开发中形成质量的关键环节。开发中形成质量的关键环节。(2)软件设计是开发阶段最重要的步骤,是将用户需求准确地转化为最终的软件产品的)软件设计是开发阶段最重要的步骤,是将用户需求准确地转化为最终的软件产品的唯一途径。唯一途径。(3)软件设计作出的决策,最终将直接影响软件实现的成败。)软件设计作出的决策,最终将直接影响软件实现的成败。(4)软件设计是软件工程和软件维护的基
4、础。)软件设计是软件工程和软件维护的基础。4.1.1 软件设计的概念与重要性软件设计的概念与重要性4目录页4.1软件设计概述第4章从工程管理的角度来看,可以将软件设计分为两个阶段:概要设计(又称总体设计)阶段从工程管理的角度来看,可以将软件设计分为两个阶段:概要设计(又称总体设计)阶段和详细设计(又称过程设计)阶段。概要设计阶段得到软件系统的基本框架,详细设计阶段明和详细设计(又称过程设计)阶段。概要设计阶段得到软件系统的基本框架,详细设计阶段明确系统内部的实现细节。确系统内部的实现细节。4.1.2 软件设计的任务软件设计的任务5目录页4.2 概要设计的任务与步骤第4章概要设计的基本任务是:概
5、要设计的基本任务是:(1)设计软件系统结构;)设计软件系统结构;(2)数据结构及数据库设计;)数据结构及数据库设计;(3)编写概要设计文档;)编写概要设计文档;(4)评审概要设计文档。)评审概要设计文档。4.2.1 概要设计的任务概要设计的任务6目录页4.2 概要设计的任务与步骤第4章概要设计的一般步骤如下:概要设计的一般步骤如下:1.选定体系结构选定体系结构2.确定设计方案确定设计方案3.设计软件结构设计软件结构4.数据结构及数据库设计数据结构及数据库设计5.制订测试计划制订测试计划6.编写概要设计文档编写概要设计文档7.概要设计文档评审概要设计文档评审4.2.2 概要设计的步骤概要设计的步
6、骤7目录页4.3 概要设计的原则第4章1.模块化模块化模块化是模块化是“分而治之分而治之”策略的具体表现。模块化就是将整体软件划分成独立命名且可独立策略的具体表现。模块化就是将整体软件划分成独立命名且可独立访问的模块,不同的模块通常具有不同访问的模块,不同的模块通常具有不同的功能或职责。每个模块可独立地开发、的功能或职责。每个模块可独立地开发、测试,最后组装成完整的软件。在结构测试,最后组装成完整的软件。在结构化方法中,函数、过程和子程序等都可化方法中,函数、过程和子程序等都可作为模块;在面向对象方法中,对象、作为模块;在面向对象方法中,对象、对象内的方法也是模块。模块是构成软对象内的方法也是
7、模块。模块是构成软件的基本构件。件的基本构件。8目录页4.3 概要设计的原则第4章2.抽象与分解抽象与分解抽象是指忽视一个主题中与当前目标无关的方面,以便更充分地注意与当前目标有关的方抽象是指忽视一个主题中与当前目标无关的方面,以便更充分地注意与当前目标有关的方面。抽象可以分成若干级别,级别越高,细节越少。其实整个软件的开发过程就是一个从抽象面。抽象可以分成若干级别,级别越高,细节越少。其实整个软件的开发过程就是一个从抽象到具体的过程:需求分析时,使用问题域语言来概括性地描述解决方案,抽象级别最高;软件到具体的过程:需求分析时,使用问题域语言来概括性地描述解决方案,抽象级别最高;软件设计时,同
8、时使用面向问题域和面向实现的两种术语描述解决方案,抽象级别次之;在编码时,设计时,同时使用面向问题域和面向实现的两种术语描述解决方案,抽象级别次之;在编码时,使用直接实现的方式(源程序代码)来描述解决方案,抽象级别最低。在软件设计中,过程抽使用直接实现的方式(源程序代码)来描述解决方案,抽象级别最低。在软件设计中,过程抽象和数据抽象是两种常用的抽象手段。象和数据抽象是两种常用的抽象手段。9目录页4.3 概要设计的原则第4章3.信息隐蔽和局部化信息隐蔽和局部化信息隐蔽是指模块所包含的信息,不允许其他不需要这些信息的模块访问,独立的模块间信息隐蔽是指模块所包含的信息,不允许其他不需要这些信息的模块
9、访问,独立的模块间仅仅交换为完成系统功能而必须交换的信息。信息隐蔽的目的是提高模块的独立性,减少修改仅仅交换为完成系统功能而必须交换的信息。信息隐蔽的目的是提高模块的独立性,减少修改或维护时的影响面。或维护时的影响面。局部化就是把关系密切的软件元素物理地放得彼此靠近。其优点是可维护性、可靠性和可局部化就是把关系密切的软件元素物理地放得彼此靠近。其优点是可维护性、可靠性和可理解性好。理解性好。4.模块独立性模块独立性模块独立性概括了把软件划分为模块时要遵守的准则,也是判断模块构造是否合理的标准。模块独立性概括了把软件划分为模块时要遵守的准则,也是判断模块构造是否合理的标准。模块独立性好的软件接口
10、简单、容易开发,独立的模块也容易测试和维护。因此,模块独立性模块独立性好的软件接口简单、容易开发,独立的模块也容易测试和维护。因此,模块独立性是软件质量的关键。是软件质量的关键。10目录页4.3 概要设计的原则第4章5.复用性设计复用性设计复用是指同一事物不做修改或稍加修改就可以多次重复使用。将复用思想用于软件开发称复用是指同一事物不做修改或稍加修改就可以多次重复使用。将复用思想用于软件开发称为软件复用,将软件的重用部分称为软构件。也就是说,在构造软件系统时不必从零做起,可为软件复用,将软件的重用部分称为软构件。也就是说,在构造软件系统时不必从零做起,可通过直接使用或加以修改已有软构件来组装成
11、新系统。通过直接使用或加以修改已有软构件来组装成新系统。软件复用可提高软件的生产率。由于软构件是经过反复使用验证的,自身具有较高的质量,软件复用可提高软件的生产率。由于软构件是经过反复使用验证的,自身具有较高的质量,因此由软构件组成的新系统也具有较高的质量。软件复用并不局限于软件代码,其范围也可扩因此由软构件组成的新系统也具有较高的质量。软件复用并不局限于软件代码,其范围也可扩展到软件开发各个阶段,包括需求模型和规格说明、设计模型、文档、测试用例等。展到软件开发各个阶段,包括需求模型和规格说明、设计模型、文档、测试用例等。11目录页4.4 模块的独立性第4章模块独立性是指软件系统中每个模块只涉
12、及软件要求的具体的子功能,而与软件系统中其模块独立性是指软件系统中每个模块只涉及软件要求的具体的子功能,而与软件系统中其他模块的接口是简单的。模块独立性取决于模块的内部和外部特征。一般用耦合和内聚两个定他模块的接口是简单的。模块独立性取决于模块的内部和外部特征。一般用耦合和内聚两个定性的指标来度量。性的指标来度量。耦合是模块之间相互依赖的紧密程度的度量,内聚是一个模块内部各个元素之间彼此结合耦合是模块之间相互依赖的紧密程度的度量,内聚是一个模块内部各个元素之间彼此结合的紧密程度的度量。一个模块内部各个元素之间的联系越紧密,则模块的内聚度就越高,相对的紧密程度的度量。一个模块内部各个元素之间的联
13、系越紧密,则模块的内聚度就越高,相对地,它与其他模块之间的耦合就越低,模块的独立性就越强。一个优秀的软件设计,应尽量做地,它与其他模块之间的耦合就越低,模块的独立性就越强。一个优秀的软件设计,应尽量做到高内聚、低耦合,从而提高模块的独立性。到高内聚、低耦合,从而提高模块的独立性。12目录页4.4 模块的独立性第4章耦合是模块之间相互连接的紧密程度的度量。耦合强弱取决于模块间接口的复杂程度、进耦合是模块之间相互连接的紧密程度的度量。耦合强弱取决于模块间接口的复杂程度、进入或访问一个模块的点以及通过接口的数据。模块之间的连接越紧密,联系越多,耦合性就越入或访问一个模块的点以及通过接口的数据。模块之
14、间的连接越紧密,联系越多,耦合性就越高,而其模块独立性就越弱。通常希望一个软件系统具有较低的耦合性。高,而其模块独立性就越弱。通常希望一个软件系统具有较低的耦合性。4.4.1 耦合性(耦合性(Coupling)13目录页4.4 模块的独立性第4章1.非直接耦合非直接耦合两个模块间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现的。耦两个模块间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现的。耦合度最弱,模块独立性最强。合度最弱,模块独立性最强。2.数据耦合数据耦合调用模块和被调用模块之间只传递简单的数据调用模块和被调用模块之间只传递简单的数据项参数。相当于高级语言
15、中的值传递。项参数。相当于高级语言中的值传递。4.4.1 耦合性(耦合性(Coupling)14目录页4.4 模块的独立性第4章3.标记耦合标记耦合调用模块和被调用模块之间传递数据结构而不是简单数据。也称特征耦合。调用模块和被调用模块之间传递数据结构而不是简单数据。也称特征耦合。标记耦合的模块间传递的不是简单变量,而是像高级语言中的数组名、记录名和文件名等标记耦合的模块间传递的不是简单变量,而是像高级语言中的数组名、记录名和文件名等数据结构,这些名字即为标记,其实传递的是地址。数据结构,这些名字即为标记,其实传递的是地址。4.4.1 耦合性(耦合性(Coupling)15目录页4.4 模块的独
16、立性第4章4.控制耦合控制耦合模块之间传递的不是数据信息,而是控制信息如标志、开关量,一个模块控制了另一模块模块之间传递的不是数据信息,而是控制信息如标志、开关量,一个模块控制了另一模块的功能。的功能。4.4.1 耦合性(耦合性(Coupling)16目录页4.4 模块的独立性第4章5.外部耦合外部耦合一组模块都访问同一全局简单变量,而且不通过参数表传递该全局变量的信息,则称之为一组模块都访问同一全局简单变量,而且不通过参数表传递该全局变量的信息,则称之为外部耦合。外部耦合。6.公共耦合公共耦合若一组模块都访问同一全局数据结构,则称之为公共耦合。公共数据环境可以是全局数据若一组模块都访问同一全
17、局数据结构,则称之为公共耦合。公共数据环境可以是全局数据结构、共享的通信区、内存的公共覆盖区等。结构、共享的通信区、内存的公共覆盖区等。如果模块只是向公共数据环境输入数据,或是只从公共数据环境取出数据,这属于比较松如果模块只是向公共数据环境输入数据,或是只从公共数据环境取出数据,这属于比较松散的公共耦合;如果模块既向公共数据环境输入数据又从公共数据环境取出数据,这属于较紧散的公共耦合;如果模块既向公共数据环境输入数据又从公共数据环境取出数据,这属于较紧密的公共耦合。密的公共耦合。4.4.1 耦合性(耦合性(Coupling)17目录页4.4 模块的独立性第4章7.内容耦合内容耦合一个模块直接访
18、问另一模块的内容,则称这两个模块为内容耦合。一个模块直接访问另一模块的内容,则称这两个模块为内容耦合。若在程序中出现下列情况之一,则说明两个模块之间发生了内容耦合:若在程序中出现下列情况之一,则说明两个模块之间发生了内容耦合:(1)一个模块直接访问另一个模块的内部数据)一个模块直接访问另一个模块的内部数据;(2)一个模块不通过正常入口而直接转入到另一个模块的内部)一个模块不通过正常入口而直接转入到另一个模块的内部;(3)两个模块有一部分代码重叠(该部分代码具有一定的独立功能)两个模块有一部分代码重叠(该部分代码具有一定的独立功能);(4)一个模块有多个入口。)一个模块有多个入口。4.4.1 耦
19、合性(耦合性(Coupling)18目录页4.4 模块的独立性第4章一个模块内各个元素彼此结合的紧密程度用内聚(或称聚合)来度量。一个理想的模块只一个模块内各个元素彼此结合的紧密程度用内聚(或称聚合)来度量。一个理想的模块只完成一个功能,模块设计的目标之一是尽可能高内聚。完成一个功能,模块设计的目标之一是尽可能高内聚。4.4.2 内聚性(内聚性(Cohesion)19目录页4.4 模块的独立性第4章1.偶然内聚偶然内聚一个模块内的各处理元素之间没有任何联系,只是偶然地被凑到一起。这种模块也称巧合一个模块内的各处理元素之间没有任何联系,只是偶然地被凑到一起。这种模块也称巧合内聚,内聚程度最低。内
20、聚,内聚程度最低。4.4.2 内聚性(内聚性(Cohesion)20目录页4.4 模块的独立性第4章2.逻辑内聚逻辑内聚指模块内执行几个逻辑上相关的功能,通过参数确定该模块完成哪一个功能。指模块内执行几个逻辑上相关的功能,通过参数确定该模块完成哪一个功能。4.4.2 内聚性(内聚性(Cohesion)21目录页4.4 模块的独立性第4章3.时间内聚时间内聚把需要同时或顺序执行的动作组合在一起形成的模块。把需要同时或顺序执行的动作组合在一起形成的模块。时间内聚模块中的功能元素只因时间因素关联在一起,各元素之间没有共用数据,而且一时间内聚模块中的功能元素只因时间因素关联在一起,各元素之间没有共用数
21、据,而且一般情况下各部分可以以任意次序执行。般情况下各部分可以以任意次序执行。4.过程内聚过程内聚如果一个模块内的处理元素是相关的,而且必须以特定次序执行则称为过程内聚。如果一个模块内的处理元素是相关的,而且必须以特定次序执行则称为过程内聚。4.4.2 内聚性(内聚性(Cohesion)22目录页4.4 模块的独立性第4章5.通信内聚通信内聚指模块内所有处理功能都通过公用数据而发生关系。即模块内各个组成部分都使用相同的指模块内所有处理功能都通过公用数据而发生关系。即模块内各个组成部分都使用相同的输入数据或产生相同的输出结果。输入数据或产生相同的输出结果。4.4.2 内聚性(内聚性(Cohesi
22、on)23目录页4.4 模块的独立性第4章6.顺序内聚顺序内聚指一个模块中各个处理元素和同一个功能密切相关,而且这些处理必须顺序执行,通常前指一个模块中各个处理元素和同一个功能密切相关,而且这些处理必须顺序执行,通常前一个处理元素的输出是后一个处理元素的输入。一个处理元素的输出是后一个处理元素的输入。顺序内聚的内聚度比较高,但缺点是不如功能内聚易于维护。顺序内聚的内聚度比较高,但缺点是不如功能内聚易于维护。7.功能内聚功能内聚指模块内所有元素的各个组成部分全部都为完成同一个功能而存在,共同完成一个单一的指模块内所有元素的各个组成部分全部都为完成同一个功能而存在,共同完成一个单一的功能,模块已不
23、可再分。即模块仅包括为完成某个功能所必须的所有成分,这些成分紧密联系、功能,模块已不可再分。即模块仅包括为完成某个功能所必须的所有成分,这些成分紧密联系、缺一不可。缺一不可。4.4.2 内聚性(内聚性(Cohesion)24目录页4.4 模块的独立性第4章1.模块功能的完善化模块功能的完善化2.消除重复功能,改善软件结构消除重复功能,改善软件结构3.模块规模应该适中模块规模应该适中4.模块的深度、宽度、扇出和扇入都应适当模块的深度、宽度、扇出和扇入都应适当5.模块的作用范围应该在控制范围之内模块的作用范围应该在控制范围之内6.力争降低模块接口的复杂程度力争降低模块接口的复杂程度7.设计单入口、
24、单出口的模块设计单入口、单出口的模块8.模块功能应该可以预测模块功能应该可以预测4.4.2 软件结构优化准则软件结构优化准则25目录页4.5 软件结构设计的图形工具第4章层次图(层次图(Hierarchy)也称)也称H图,用于表示软件的层次结构,特别适合于在自顶向下设计时图,用于表示软件的层次结构,特别适合于在自顶向下设计时使用。使用。4.5.1 层次图层次图26目录页4.5 软件结构设计的图形工具第4章IPO图是输入图是输入/处理处理/输出图(输出图(Input Process Output),其基本形式是三个方框,左边方框列),其基本形式是三个方框,左边方框列出所有的输入数据,中间框列出主
25、要的处理,右边框列出输出数据。出所有的输入数据,中间框列出主要的处理,右边框列出输出数据。4.5.2 IPO图图27目录页4.5 软件结构设计的图形工具第4章模块结构图(模块结构图(Structure Chart,SC图)用于表示软件系统的层次分解关系、模块调用关系、图)用于表示软件系统的层次分解关系、模块调用关系、模块之间数据流和控制信息流的传递关系,是描述软件系统物理模型、进行概要设计的主要工模块之间数据流和控制信息流的传递关系,是描述软件系统物理模型、进行概要设计的主要工具,也是软件文档的一部分。具,也是软件文档的一部分。4.5.3 结构图结构图28目录页4.6 结构化的设计方法第4章结
26、构化设计方法是面向数据流的设计方法,它以数据流图为基础,定义了将数据流图映射结构化设计方法是面向数据流的设计方法,它以数据流图为基础,定义了将数据流图映射为软件结构图(即为软件结构图(即DFDSC)的方法,而数据流的类型决定了映射的方法。数据流分为变换流)的方法,而数据流的类型决定了映射的方法。数据流分为变换流和事务流两种,因此由数据流组成的数据流图也分为变换型数据流图和事务型数据流图两种类和事务流两种,因此由数据流组成的数据流图也分为变换型数据流图和事务型数据流图两种类型。由变换型数据流图向结构图的映射称变换分析,由事务型数据流图向结构图的映射称事务型。由变换型数据流图向结构图的映射称变换分
27、析,由事务型数据流图向结构图的映射称事务分析。分析。29目录页4.6 结构化的设计方法第4章1数据流图的类型数据流图的类型(1)变换流)变换流变换型数据流的特征是可以把它看成由输入、变换中心和输出三部分组成,这样的数据流变换型数据流的特征是可以把它看成由输入、变换中心和输出三部分组成,这样的数据流图称为变换型数据流图。如图图称为变换型数据流图。如图4-20所示。所示。30目录页4.6 结构化的设计方法第4章(2)事务流)事务流事务型数据流的特征是可以把它看成具有在多种事务中选择执行某类事务的能力。这样的事务型数据流的特征是可以把它看成具有在多种事务中选择执行某类事务的能力。这样的数据流图称为事
28、务型数据流图。数据流图称为事务型数据流图。31目录页4.6 结构化的设计方法第4章2.结构化设计过程结构化设计过程面向数据流的结构化方法的设计面向数据流的结构化方法的设计过程如图过程如图4-22所示。所示。32目录页4.6 结构化的设计方法第4章(1)精化)精化DFD。(2)确定)确定DFD类型。类型。(3)把)把DFD映射到系统模块结构,设计模块结构的上层。映射到系统模块结构,设计模块结构的上层。(4)基于)基于DFD逐步分解高层模块,设计出下层模块。逐步分解高层模块,设计出下层模块。(5)根据模块独立性原理,精化模块结构。)根据模块独立性原理,精化模块结构。(6)描述模块接口。)描述模块接
29、口。33目录页4.6 结构化的设计方法第4章两种映射方法都是先映射出初始软件结构图。两种映射方法都是先映射出初始软件结构图。34目录页4.6 结构化的设计方法第4章3.变换分析变换分析变换分析是一系列设计步骤的总称,通过执行这些步骤,将具有变换流特点的数据流图按变换分析是一系列设计步骤的总称,通过执行这些步骤,将具有变换流特点的数据流图按预先确定的模式映射成软件结构。采用变换分析方法开发出的软件结构图,其一般方式为:预先确定的模式映射成软件结构。采用变换分析方法开发出的软件结构图,其一般方式为:“输入输入处理处理输出输出”。变换分析方法的设计步骤如下:变换分析方法的设计步骤如下:第一步复查基本
30、系统模型。以确定输入数据和输出数据是否与实际相符。第一步复查基本系统模型。以确定输入数据和输出数据是否与实际相符。第二步复查并精化数据流图。完成对需求分析阶段得出的数据流图的复查和精化。第二步复查并精化数据流图。完成对需求分析阶段得出的数据流图的复查和精化。第三步判断数据流图具有变换特性还是事务特性。根据数据流图中占优势的属性是事务的第三步判断数据流图具有变换特性还是事务特性。根据数据流图中占优势的属性是事务的还是变换的,来确定数据流的全局属性。还是变换的,来确定数据流的全局属性。第四步确定输入流和输出流的边界,从而将变换中心划分出来。第四步确定输入流和输出流的边界,从而将变换中心划分出来。第
31、五步完成第五步完成“第一级分解第一级分解”。分配控制的过程,划分顶层模块和从属模块。分配控制的过程,划分顶层模块和从属模块。第六步完成第六步完成“第二级分解第二级分解”。就是把数据流图中的每个处理映射成软件结构中一个适当的。就是把数据流图中的每个处理映射成软件结构中一个适当的模块。模块。第七步采用启发式设计规则和设计度量对得到的软件结构进行精化。第七步采用启发式设计规则和设计度量对得到的软件结构进行精化。35目录页4.6 结构化的设计方法第4章4.事务分析事务分析事务分析的设计步骤和变换分析的设计步骤基本类似,主要差别在于数据流图到软件结事务分析的设计步骤和变换分析的设计步骤基本类似,主要差别
32、在于数据流图到软件结构的映射方法不同。在事务分析的设计中,由数据流图映射到软件结构时,从事务中心边界构的映射方法不同。在事务分析的设计中,由数据流图映射到软件结构时,从事务中心边界开始,把接收通路映射成一个模块,在发送通路设立一个控制模块,用以控制由不同发送通开始,把接收通路映射成一个模块,在发送通路设立一个控制模块,用以控制由不同发送通路映射成的分支模块。路映射成的分支模块。36目录页4.7 概要设计文档与评审第4章软件设计规格说明书是软件设计阶段要完成的文档,作为设计任务的最终成果。概要软件设计规格说明书是软件设计阶段要完成的文档,作为设计任务的最终成果。概要设计、详细设计、数据设计规格说
33、明书可根据项目的大小分别编写或合并为一份设计规格说设计、详细设计、数据设计规格说明书可根据项目的大小分别编写或合并为一份设计规格说明书。我国国家标准明书。我国国家标准GB/T 8567|2006计算机软件文档编制规范计算机软件文档编制规范都给出了设计说明书的都给出了设计说明书的内容框架,可以选择使用。本章内容框架,可以选择使用。本章4.8节给出的节给出的“高校图书管理系统高校图书管理系统”软件概要设计说明书软件概要设计说明书可供读者参考。可供读者参考。4.7.1 概要设计说明书的编写内容概要设计说明书的编写内容37目录页4.7 概要设计文档与评审第4章设计评审就是对设计文档的评审。目的是为了尽
34、早发现软件的欠缺并尽早纠正,因此设计评审就是对设计文档的评审。目的是为了尽早发现软件的欠缺并尽早纠正,因此评审对于项目的成功是绝对必要的。评审对于项目的成功是绝对必要的。(1)评审的指导原则)评审的指导原则概要设计评审和详细设计评审应分开进行,不可合并为一次评审;概要设计评审和详细设计评审应分开进行,不可合并为一次评审;概要设计评审应邀请用户代表和有关领域专家到会,详细设计评审则不需要;概要设计评审应邀请用户代表和有关领域专家到会,详细设计评审则不需要;评审是为了提前揭露错误,参加评审的设计人员应该欢迎别人提出批评和建议,不要评审是为了提前揭露错误,参加评审的设计人员应该欢迎别人提出批评和建议
35、,不要掩盖设计的缺陷。评审的对象是设计文档而不是设计者;掩盖设计的缺陷。评审的对象是设计文档而不是设计者;评审中提出的问题应详细记录,但不谋求当场解决;评审中提出的问题应详细记录,但不谋求当场解决;评审结束前应做出本次评审能否通过的结论。评审结束前应做出本次评审能否通过的结论。4.7.2 概要设计评审概要设计评审38目录页4.7 概要设计文档与评审第4章(2)评审的主要内容)评审的主要内容概要设计评审应该把重点放在系统的总体结构、模块划分、内外接口等方面。如软件概要设计评审应该把重点放在系统的总体结构、模块划分、内外接口等方面。如软件结构能否满足需求;结构形态是否合理;层次是否清晰;模块划分是
36、否符合优化原则;人机结构能否满足需求;结构形态是否合理;层次是否清晰;模块划分是否符合优化原则;人机界面、内外部接口和出错处理是否合理等。界面、内外部接口和出错处理是否合理等。详细设计评审的重点应该放在各个模块的具体设计上。如模块的设计能否满足其功能详细设计评审的重点应该放在各个模块的具体设计上。如模块的设计能否满足其功能和性能要求;算法和数据结构是否合理;设计描述是否简单、清晰等。和性能要求;算法和数据结构是否合理;设计描述是否简单、清晰等。4.7.2 概要设计评审概要设计评审39目录页4.7 概要设计文档与评审第4章(3)评审的方式)评审的方式评审分为正式和非正式两种方式。评审分为正式和非
37、正式两种方式。非正式评审参加人数少,且均为软件人员,带有同行讨论性质,不拘泥于时间和形式,非正式评审参加人数少,且均为软件人员,带有同行讨论性质,不拘泥于时间和形式,适宜详细设计评审。适宜详细设计评审。正式评审除软件开发人员外,还应邀请用户代表和有关领域专家参加。通常采用答辩正式评审除软件开发人员外,还应邀请用户代表和有关领域专家参加。通常采用答辩方式,与会者提前审阅文档资料,设计人员使用幻灯片等方式对设计方案详细说明之后,回方式,与会者提前审阅文档资料,设计人员使用幻灯片等方式对设计方案详细说明之后,回答与会者的问题并记录各种重要的评审意见。正式评审是概要设计评审的常用方式。答与会者的问题并记录各种重要的评审意见。正式评审是概要设计评审的常用方式。4.7.2 概要设计评审概要设计评审40目录页4.8 实例分析:“高校图书管理系统”概要设计第4章E-mail:网址网址:http:/地址:大连市软件园路地址:大连市软件园路80号号大连理工大学出版社谢谢观看
限制150内