软件工程课件(精品).ppt

上传人:hwp****526 文档编号:85520646 上传时间:2023-04-11 格式:PPT 页数:72 大小:1.06MB
返回 下载 相关 举报
软件工程课件(精品).ppt_第1页
第1页 / 共72页
软件工程课件(精品).ppt_第2页
第2页 / 共72页
点击查看更多>>
资源描述

《软件工程课件(精品).ppt》由会员分享,可在线阅读,更多相关《软件工程课件(精品).ppt(72页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、情景情景1.4 1.4 总体设计总体设计第第4章章 总体设计总体设计 可行性分析可行性分析可行性分析可行性分析 -Why?Who?Why?Who?Why?Who?Why?Who?需求分析需求分析需求分析需求分析 -What?What?What?What?设计设计设计设计 -How do?How do?How do?How do?总体设计总体设计总体设计总体设计 (概要设计概要设计概要设计概要设计)确定软件的结构确定软件的结构确定软件的结构确定软件的结构以以以以及及及及 各组成成分各组成成分各组成成分各组成成分(子系统或模块子系统或模块子系统或模块子系统或模块)之间的相互关系之间的相互关系之间的

2、相互关系之间的相互关系 设计设计设计设计 详细设计确定模块内部的算法和数据结构,详细设计确定模块内部的算法和数据结构,详细设计确定模块内部的算法和数据结构,详细设计确定模块内部的算法和数据结构,产生描述各模块程序过程的详细文档。产生描述各模块程序过程的详细文档。产生描述各模块程序过程的详细文档。产生描述各模块程序过程的详细文档。总体设计的任务总体设计的任务划分出组成系统的物理元素划分出组成系统的物理元素程序、文件、程序、文件、数据库、人工过程和文档等,但是每个物数据库、人工过程和文档等,但是每个物理元素仍然处于黑盒子级,这些黑盒子里理元素仍然处于黑盒子级,这些黑盒子里的具体内容将在以后仔细设计

3、。的具体内容将在以后仔细设计。设计软件的结构设计软件的结构,也就是要确定系统中每,也就是要确定系统中每个程序是由哪些模块组成的,以及这些模个程序是由哪些模块组成的,以及这些模块相互间的关系。块相互间的关系。总体设计的必要性:可以站在全局高度上,花较少成本,从较抽象的层次上分析对比多种可能的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。4.1 4.1 设计过程设计过程总体设计过程通常由两个主要阶段组成:总体设计过程通常由两个主要阶段组成:-系统设计阶段,确定系统的具体实现方案;系统设计阶段,确定系统的具体实现方案;-结构设计阶段,确定软件结构

4、。结构设计阶段,确定软件结构。典型的总体设计过程包括下述9个步骤:1.1.设想供选择的方案设想供选择的方案 2.2.选取合理的方案选取合理的方案 3.3.推荐最佳方案推荐最佳方案 4.4.功能分解功能分解 5.5.设计软件结构设计软件结构 6.6.设计数据库设计数据库 7.7.制定测试计划制定测试计划 8.8.书写文档书写文档 9.9.审查和复审审查和复审总体设计所总体设计所书写的文档书写的文档(1)(1)(1)(1)总体设计说明总体设计说明总体设计说明总体设计说明 主要内容包括用系统流程图描绘的系统主要内容包括用系统流程图描绘的系统主要内容包括用系统流程图描绘的系统主要内容包括用系统流程图描

5、绘的系统构成方案,组成系统的物理元素清单,成本构成方案,组成系统的物理元素清单,成本构成方案,组成系统的物理元素清单,成本构成方案,组成系统的物理元素清单,成本/效益分析;效益分析;效益分析;效益分析;对最佳方案的概括描述,精化的数据流图,用层次图或对最佳方案的概括描述,精化的数据流图,用层次图或对最佳方案的概括描述,精化的数据流图,用层次图或对最佳方案的概括描述,精化的数据流图,用层次图或结构图描绘的软件结构,用结构图描绘的软件结构,用结构图描绘的软件结构,用结构图描绘的软件结构,用IPOIPOIPOIPO图或其他工具简要描述的图或其他工具简要描述的图或其他工具简要描述的图或其他工具简要描述

6、的各个模块的算法,模块间的接口关系,以及需求、功能各个模块的算法,模块间的接口关系,以及需求、功能各个模块的算法,模块间的接口关系,以及需求、功能各个模块的算法,模块间的接口关系,以及需求、功能和模块三者之间的交叉参照关系等等。和模块三者之间的交叉参照关系等等。和模块三者之间的交叉参照关系等等。和模块三者之间的交叉参照关系等等。(2)(2)(2)(2)用户手册用户手册用户手册用户手册 根据总体设计阶段的结果,修改更正在需求根据总体设计阶段的结果,修改更正在需求根据总体设计阶段的结果,修改更正在需求根据总体设计阶段的结果,修改更正在需求分析阶段产生的初步的用户手册。分析阶段产生的初步的用户手册。

7、分析阶段产生的初步的用户手册。分析阶段产生的初步的用户手册。(3)(3)(3)(3)测试计划测试计划测试计划测试计划 包括测试策略,测试方案,预期的测试结果,包括测试策略,测试方案,预期的测试结果,包括测试策略,测试方案,预期的测试结果,包括测试策略,测试方案,预期的测试结果,测试进度计划等等。测试进度计划等等。测试进度计划等等。测试进度计划等等。(4)(4)(4)(4)详细的实现计划详细的实现计划详细的实现计划详细的实现计划(5)(5)(5)(5)数据库设计结果数据库设计结果数据库设计结果数据库设计结果概要设计说明书(概要设计说明书(GB856788GB856788)4.2 4.2 设计原理

8、设计原理 模块化模块化 抽抽 象象 逐步求精逐步求精 信息隐藏和局部化信息隐藏和局部化 模块独立模块独立4.2.1 4.2.1 模块化模块化模块模块模块模块是由边界元素限定的相邻程序元素(例如,是由边界元素限定的相邻程序元素(例如,是由边界元素限定的相邻程序元素(例如,是由边界元素限定的相邻程序元素(例如,数据说明,可执行的语句)的序列,而且有一个数据说明,可执行的语句)的序列,而且有一个数据说明,可执行的语句)的序列,而且有一个数据说明,可执行的语句)的序列,而且有一个总体标识符代表它。总体标识符代表它。总体标识符代表它。总体标识符代表它。-如:过程、函数、子程序、宏、对象等,都可作为模块。

9、如:过程、函数、子程序、宏、对象等,都可作为模块。如:过程、函数、子程序、宏、对象等,都可作为模块。如:过程、函数、子程序、宏、对象等,都可作为模块。模块化模块化模块化模块化就是把程序划分成独立命名且可独立访问就是把程序划分成独立命名且可独立访问就是把程序划分成独立命名且可独立访问就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这些模块的模块,每个模块完成一个子功能,把这些模块的模块,每个模块完成一个子功能,把这些模块的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满集成起来构成一个整体,可以完成指定的功能满集成起来构成一个整体,可以完成

10、指定的功能满集成起来构成一个整体,可以完成指定的功能满足用户的需求。足用户的需求。足用户的需求。足用户的需求。问题:模块该如何划分?问题:模块该如何划分?设:设:C(xC(x)为为复杂程度函数复杂程度函数 E(xE(x)为决定解决问题为决定解决问题x x所需的所需的 工作量工作量(时间时间)函数函数 对于两个问题对于两个问题对于两个问题对于两个问题P1P1P1P1和和和和P2P2P2P2,如果如果如果如果 C(P1)C(P2)C(P1)C(P2)C(P1)C(P2)C(P1)C(P2)则:则:E(P1)E(P2)E(P1)E(P2)E(P1)E(P2)E(P1)E(P2)如果如果如果如果 C(

11、P1+P2)C(P1)+C(P2)C(P1+P2)C(P1)+C(P2)C(P1+P2)C(P1)+C(P2)C(P1+P2)C(P1)+C(P2)则:则:E(P1+P2)E(P1)+E(P2)E(P1+P2)E(P1)+E(P2)E(P1+P2)E(P1)+E(P2)E(P1+P2)E(P1)+E(P2)这个不等式导致这个不等式导致这个不等式导致这个不等式导致“各个击破各个击破各个击破各个击破”的的的的结论结论结论结论把复杂的问题分解成许多把复杂的问题分解成许多把复杂的问题分解成许多把复杂的问题分解成许多容易解决的小问题,原来的问题容易解决的小问题,原来的问题容易解决的小问题,原来的问题容易

12、解决的小问题,原来的问题也就容易解决了。这就是模块化也就容易解决了。这就是模块化也就容易解决了。这就是模块化也就容易解决了。这就是模块化的根据。的根据。的根据。的根据。最小成本区M模块成本接口成本总成本软件开发工作量 模块数 4.2.2 4.2.2 抽象抽象 人类在认识复杂现象的过程中使用的最强有力的思维工具是人类在认识复杂现象的过程中使用的最强有力的思维工具是人类在认识复杂现象的过程中使用的最强有力的思维工具是人类在认识复杂现象的过程中使用的最强有力的思维工具是抽抽抽抽象。象。象。象。-就是抽出事物的就是抽出事物的就是抽出事物的就是抽出事物的本质特性(共性),本质特性(共性),本质特性(共性

13、),本质特性(共性),而暂时不考虑它们的细节。而暂时不考虑它们的细节。而暂时不考虑它们的细节。而暂时不考虑它们的细节。处理复杂系统的惟一有效的方法是用处理复杂系统的惟一有效的方法是用处理复杂系统的惟一有效的方法是用处理复杂系统的惟一有效的方法是用层次层次层次层次的方式构造和分析它。的方式构造和分析它。的方式构造和分析它。的方式构造和分析它。-在抽象的在抽象的在抽象的在抽象的最高层次使用问题环境的语言最高层次使用问题环境的语言最高层次使用问题环境的语言最高层次使用问题环境的语言,以概括的方式叙述问题的解,以概括的方式叙述问题的解,以概括的方式叙述问题的解,以概括的方式叙述问题的解法;在法;在法;

14、在法;在较低抽象层次采用更过程化的方法较低抽象层次采用更过程化的方法较低抽象层次采用更过程化的方法较低抽象层次采用更过程化的方法,把面向问题的术语和面向实现,把面向问题的术语和面向实现,把面向问题的术语和面向实现,把面向问题的术语和面向实现的术语结合起来叙述问题的解法;最后在的术语结合起来叙述问题的解法;最后在的术语结合起来叙述问题的解法;最后在的术语结合起来叙述问题的解法;最后在最低的抽象层次用可直接实现的最低的抽象层次用可直接实现的最低的抽象层次用可直接实现的最低的抽象层次用可直接实现的方式叙述问题的解法。方式叙述问题的解法。方式叙述问题的解法。方式叙述问题的解法。软件工程过程的每一步都是

15、对软件解法的抽象层次的一次精化。软件工程过程的每一步都是对软件解法的抽象层次的一次精化。软件工程过程的每一步都是对软件解法的抽象层次的一次精化。软件工程过程的每一步都是对软件解法的抽象层次的一次精化。在在在在可行性研究阶段可行性研究阶段可行性研究阶段可行性研究阶段,软件作为系统的一个完整部件;在,软件作为系统的一个完整部件;在,软件作为系统的一个完整部件;在,软件作为系统的一个完整部件;在需求分析期间需求分析期间需求分析期间需求分析期间,软,软,软,软件解法是使用在问题环境内熟悉的方式描述的;当件解法是使用在问题环境内熟悉的方式描述的;当件解法是使用在问题环境内熟悉的方式描述的;当件解法是使用

16、在问题环境内熟悉的方式描述的;当由总体设计向详细设计由总体设计向详细设计由总体设计向详细设计由总体设计向详细设计过渡时过渡时过渡时过渡时,抽象的程度也就随之减少了;最后,抽象的程度也就随之减少了;最后,抽象的程度也就随之减少了;最后,抽象的程度也就随之减少了;最后,当源程序写出来以后当源程序写出来以后当源程序写出来以后当源程序写出来以后,也就,也就,也就,也就达到了抽象的最低层。达到了抽象的最低层。达到了抽象的最低层。达到了抽象的最低层。4.2.3 4.2.3 逐步求精逐步求精逐步求精是人类解决复杂问题时采逐步求精是人类解决复杂问题时采用的基本方法,也是许多软件工程用的基本方法,也是许多软件工

17、程技术(例如,规格说明技术,设计技术(例如,规格说明技术,设计和实现技术)的基础。和实现技术)的基础。逐步求精定义为:逐步求精定义为:“为了能集中精为了能集中精力解决主要问题而尽量推迟对问题力解决主要问题而尽量推迟对问题细节的考虑。细节的考虑。”Magical Number Seven,Plus or Minus Two,Some Limits on Our Capacity for Processing Information The Psychological Review,1956 G.A.Miller奇妙的数字奇妙的数字 7+2,人类,人类信息处理能力的限度信息处理能力的限度 逐步求精

18、最初是由逐步求精最初是由逐步求精最初是由逐步求精最初是由NiklausNiklausNiklausNiklaus Wirth Wirth Wirth Wirth提出的一种自顶向下的设计提出的一种自顶向下的设计提出的一种自顶向下的设计提出的一种自顶向下的设计策略。策略。策略。策略。他本人的概括说明如下:他本人的概括说明如下:我们对付复杂问题的最重要的办法是抽象,因此,对一个复杂我们对付复杂问题的最重要的办法是抽象,因此,对一个复杂我们对付复杂问题的最重要的办法是抽象,因此,对一个复杂我们对付复杂问题的最重要的办法是抽象,因此,对一个复杂的问题不应该立刻用计算机指令、数字和逻辑符号来表示,而的问题

19、不应该立刻用计算机指令、数字和逻辑符号来表示,而的问题不应该立刻用计算机指令、数字和逻辑符号来表示,而的问题不应该立刻用计算机指令、数字和逻辑符号来表示,而应该用较自然的抽象语句来表示,从而得出抽象程序。抽象程应该用较自然的抽象语句来表示,从而得出抽象程序。抽象程应该用较自然的抽象语句来表示,从而得出抽象程序。抽象程应该用较自然的抽象语句来表示,从而得出抽象程序。抽象程序对抽象的数据进行某些特定的运算并用某些合适的记号(可序对抽象的数据进行某些特定的运算并用某些合适的记号(可序对抽象的数据进行某些特定的运算并用某些合适的记号(可序对抽象的数据进行某些特定的运算并用某些合适的记号(可能是自然语言

20、)来表示。对抽象程序做进一步的分解,并进入能是自然语言)来表示。对抽象程序做进一步的分解,并进入能是自然语言)来表示。对抽象程序做进一步的分解,并进入能是自然语言)来表示。对抽象程序做进一步的分解,并进入下一个抽象层次,这样的精细化过程一直进行下去,直到程序下一个抽象层次,这样的精细化过程一直进行下去,直到程序下一个抽象层次,这样的精细化过程一直进行下去,直到程序下一个抽象层次,这样的精细化过程一直进行下去,直到程序能被计算机接受为止。这时的程序可能是用某种高级语言或机能被计算机接受为止。这时的程序可能是用某种高级语言或机能被计算机接受为止。这时的程序可能是用某种高级语言或机能被计算机接受为止

21、。这时的程序可能是用某种高级语言或机器指令书写的。器指令书写的。器指令书写的。器指令书写的。抽象与求精是一对互补的概念。抽象与求精是一对互补的概念。抽象使得设计者能够说明过程和数据,同时抽象使得设计者能够说明过程和数据,同时 却忽略低层细节。事实上,可以把抽象看作却忽略低层细节。事实上,可以把抽象看作是一种通过忽略多余的细节同时强调有关的是一种通过忽略多余的细节同时强调有关的细节,而实现逐步求精的方法。细节,而实现逐步求精的方法。求精则帮助设计者在设计过程中逐步揭示出求精则帮助设计者在设计过程中逐步揭示出低层细节。低层细节。这两个概念都有助于设计者在设计演化过程这两个概念都有助于设计者在设计演

22、化过程中创造出完整的设计模型。中创造出完整的设计模型。4.2.4 4.2.4 信息隐藏和局部化信息隐藏和局部化 信息隐藏原理指出:设计和确定模块,使得一个模块内包信息隐藏原理指出:设计和确定模块,使得一个模块内包信息隐藏原理指出:设计和确定模块,使得一个模块内包信息隐藏原理指出:设计和确定模块,使得一个模块内包含的信息含的信息含的信息含的信息(过程和数据过程和数据过程和数据过程和数据)对于不需要这些信息的模块来说,对于不需要这些信息的模块来说,对于不需要这些信息的模块来说,对于不需要这些信息的模块来说,是不能访问的。是不能访问的。是不能访问的。是不能访问的。局部化的概念和信息隐藏概念是密切相关

23、的。局部化的概念和信息隐藏概念是密切相关的。局部化的概念和信息隐藏概念是密切相关的。局部化的概念和信息隐藏概念是密切相关的。所谓局部化:是指把一些关系密切的软件元素物理地放得所谓局部化:是指把一些关系密切的软件元素物理地放得所谓局部化:是指把一些关系密切的软件元素物理地放得所谓局部化:是指把一些关系密切的软件元素物理地放得彼此靠近。彼此靠近。彼此靠近。彼此靠近。-在模块中使用局部数据元素是局部化的一个例子。显然,局部化有在模块中使用局部数据元素是局部化的一个例子。显然,局部化有在模块中使用局部数据元素是局部化的一个例子。显然,局部化有在模块中使用局部数据元素是局部化的一个例子。显然,局部化有助

24、于实现信息隐藏。助于实现信息隐藏。助于实现信息隐藏。助于实现信息隐藏。如果在测试期间和以后的软件维护期间需要修改软件,那如果在测试期间和以后的软件维护期间需要修改软件,那如果在测试期间和以后的软件维护期间需要修改软件,那如果在测试期间和以后的软件维护期间需要修改软件,那么使用信息隐藏原理作为模块化系统设计的标准就会带来么使用信息隐藏原理作为模块化系统设计的标准就会带来么使用信息隐藏原理作为模块化系统设计的标准就会带来么使用信息隐藏原理作为模块化系统设计的标准就会带来极大好处。极大好处。极大好处。极大好处。4.2.5 4.2.5 模块独立模块独立 模块的独立性模块的独立性是指软件系统中每个模块只

25、是指软件系统中每个模块只涉及软件要求的具体的子功能,而和软件系统涉及软件要求的具体的子功能,而和软件系统中其他模块的接口是简单的。中其他模块的接口是简单的。耦合耦合耦合耦合 模块之间的模块之间的模块之间的模块之间的相对独立性相对独立性相对独立性相对独立性的度量的度量的度量的度量 内聚内聚内聚内聚 模块功能强模块功能强模块功能强模块功能强度的度量度的度量度的度量度的度量 模块的独立程度可以由两个定性标准度量模块的独立程度可以由两个定性标准度量1.耦合耦合 耦合性是程序结构中各个模块之间相互关联的度量耦合性是程序结构中各个模块之间相互关联的度量它取决于各个模块之间接口的复杂程度、调用模块的方它取决

26、于各个模块之间接口的复杂程度、调用模块的方式以及那些信息通过接口。式以及那些信息通过接口。低低非直接非直接非直接非直接耦合耦合耦合耦合数据数据数据数据耦合耦合耦合耦合标记标记标记标记耦合耦合耦合耦合控制控制控制控制耦合耦合耦合耦合外部外部外部外部耦合耦合耦合耦合公共公共公共公共耦合耦合耦合耦合内容内容内容内容耦合耦合耦合耦合 高高弱弱 强强耦合性耦合性模块独立性模块独立性(1)(1)非非直接耦合直接耦合两个模块没有直接关系两个模块没有直接关系两个模块没有直接关系两个模块没有直接关系(模块模块模块模块1 1 1 1和模块和模块和模块和模块2)2)2)2),模块独立性最强。模块独立性最强。模块独立

27、性最强。模块独立性最强。模块模块1 1模块模块2 2模块模块3 3模块模块4 4(2)(2)数据耦合数据耦合 一模块调用另一一模块调用另一模块时,被调用模块时,被调用模块的输入、输模块的输入、输出都是简单的数出都是简单的数据据(若干参数若干参数)。属松散耦合。属松散耦合。开发票开发票计算水费计算水费单价单价数量数量金额金额(3)(3)标记耦合标记耦合(特征耦合特征耦合)如两个模块通过传如两个模块通过传递递数据结构数据结构(不是不是简单数据简单数据,而是记而是记录、数组等录、数组等)加以加以联系联系,或都与一个或都与一个数据结构数据结构有关系有关系,则称这两个模块间则称这两个模块间存在标记偶合存

28、在标记偶合。计算水电费计算水电费计算水费计算水费计算电费计算电费住户情况住户情况水费水费 电费电费住户情况住户情况“住户情况住户情况”是一个数据结构是一个数据结构,图中图中模块都与此数据结构有关模块都与此数据结构有关.“计算水计算水费费”和和“计算电费计算电费”本无关本无关,由于引由于引用了此数据结构产生依赖关系用了此数据结构产生依赖关系,它们它们之间也是标记偶合之间也是标记偶合.(4)(4)控制耦合控制耦合 A 模块flagf1Bf2fn 如果一个模块通过传送开关、标志、名字如果一个模块通过传送开关、标志、名字 等控等控制信息,明显地控制选择另一模块的功能制信息,明显地控制选择另一模块的功能

29、 就是就是控制耦合。控制耦合。(5)(5)外部耦合外部耦合一组模块均与同一外部环境关联一组模块均与同一外部环境关联(例例如如,I/O,I/O模块与特定的设备、格式和模块与特定的设备、格式和通信协议相关联通信协议相关联),),它们之间便存在外它们之间便存在外部耦合部耦合。外部偶合必不可少外部偶合必不可少,但这种模块数目但这种模块数目应尽量少应尽量少。(6)(6)公共公共环境环境耦合耦合(公共数据区耦合公共数据区耦合)一组模块引用同一一组模块引用同一个公用数据区个公用数据区(也称也称全局数据区、公共全局数据区、公共数据环境数据环境)。公共数据区指:公共数据区指:全局数据结构全局数据结构 共享通讯区

30、共享通讯区 内存公共覆盖区等内存公共覆盖区等 ABC公共数据区公共数据区 公共耦合存在的问题:公共耦合存在的问题:(1)软件可理解性降低软件可理解性降低 (2)诊断错误困难诊断错误困难 (3)软件可维护性差,软件可维护性差,(4)软件可靠性差软件可靠性差(公共数据区及全程变量无保护措施公共数据区及全程变量无保护措施)慎用公共数据区和全程变量慎用公共数据区和全程变量!(7)(7)内容耦合内容耦合A B一模块直接一模块直接访问另一模访问另一模块的内部信块的内部信息息 (程序代程序代码或数据)码或数据)A B 模模块块代代码码重重叠叠Entry1 Entry2 多多入入口口模模块块不不正正常常转转入

31、入另另一一模模块块最不好的耦合形式!最不好的耦合形式!以上给出了以上给出了 7 7种耦合类型,这只是从耦合的机制上所种耦合类型,这只是从耦合的机制上所做的分类,按耦合的强弱程度的排列只是相对的关系。做的分类,按耦合的强弱程度的排列只是相对的关系。但它给设计人员在设计程序结构时提供了一决策准则。但它给设计人员在设计程序结构时提供了一决策准则。实际上,开始时两个模块之间的耦合不只是一种类型,实际上,开始时两个模块之间的耦合不只是一种类型,而是多种类型的混合。这就要求设计人员按照实际情而是多种类型的混合。这就要求设计人员按照实际情况进行分析、比较和分析,逐步加以改进,以提高模况进行分析、比较和分析,

32、逐步加以改进,以提高模块的独立性。块的独立性。总之,耦合是影响软件复杂程度的一个重要因素。应总之,耦合是影响软件复杂程度的一个重要因素。应该采取下述设计原则:该采取下述设计原则:尽量使用数据耦合,少用控制耦合和特征耦合,限制尽量使用数据耦合,少用控制耦合和特征耦合,限制公共环境耦合的范围,完全不用内容耦合。公共环境耦合的范围,完全不用内容耦合。2.2.内内 聚聚 一个模块内部元素在功能上相互关联的强度一个模块内部元素在功能上相互关联的强度设计目标:高内聚,模块在软件过程中完成单一的任务设计目标:高内聚,模块在软件过程中完成单一的任务(1)(1)功能内聚功能内聚 (Functional Cohe

33、sion)(Functional Cohesion)一个模块中各个部分都是一个模块中各个部分都是完成某一具体完成某一具体功能功能必不可少的组成部分,或者说该模必不可少的组成部分,或者说该模块中所有部分都是为了完成一项具体功块中所有部分都是为了完成一项具体功能而协同工作,紧密联系,不可分割的。能而协同工作,紧密联系,不可分割的。则称该模块为功能内聚模块。则称该模块为功能内聚模块。内聚性最强内聚性最强(2)(2)信息内聚信息内聚(Informational Cohesion)(Informational Cohesion)这种模块完成多个功能,这种模块完成多个功能,这种模块完成多个功能,这种模块完

34、成多个功能,各个功能都在同一数据结各个功能都在同一数据结各个功能都在同一数据结各个功能都在同一数据结构上操作,每一项功能有构上操作,每一项功能有构上操作,每一项功能有构上操作,每一项功能有一个唯一的入口点。这个一个唯一的入口点。这个一个唯一的入口点。这个一个唯一的入口点。这个模块将根据不同的要求,模块将根据不同的要求,模块将根据不同的要求,模块将根据不同的要求,确定该执行哪一个功能。确定该执行哪一个功能。确定该执行哪一个功能。确定该执行哪一个功能。由于这个模块的所有功能由于这个模块的所有功能由于这个模块的所有功能由于这个模块的所有功能都是基于同一个数据结构都是基于同一个数据结构都是基于同一个数

35、据结构都是基于同一个数据结构(符号表),因此,它是(符号表),因此,它是(符号表),因此,它是(符号表),因此,它是一个信息内聚的模块。一个信息内聚的模块。一个信息内聚的模块。一个信息内聚的模块。信息内聚模块可以看成是多个信息内聚模块可以看成是多个信息内聚模块可以看成是多个信息内聚模块可以看成是多个功能内聚模块的组合,并且达功能内聚模块的组合,并且达功能内聚模块的组合,并且达功能内聚模块的组合,并且达到信息的隐蔽。即把某个数据到信息的隐蔽。即把某个数据到信息的隐蔽。即把某个数据到信息的隐蔽。即把某个数据结构、资源或设备隐蔽在一个结构、资源或设备隐蔽在一个结构、资源或设备隐蔽在一个结构、资源或设

36、备隐蔽在一个模块内,不为别的模块所知晓模块内,不为别的模块所知晓模块内,不为别的模块所知晓模块内,不为别的模块所知晓(3)(3)通信内聚通信内聚(Communication Cohesion)(Communication Cohesion)如果一个模块内各功如果一个模块内各功如果一个模块内各功如果一个模块内各功能部分都使用了相同能部分都使用了相同能部分都使用了相同能部分都使用了相同的输入数据,或产生的输入数据,或产生的输入数据,或产生的输入数据,或产生了相同的输出数据,了相同的输出数据,了相同的输出数据,了相同的输出数据,则称之为通信内聚模则称之为通信内聚模则称之为通信内聚模则称之为通信内聚模

37、块。通常,通信内聚块。通常,通信内聚块。通常,通信内聚块。通常,通信内聚模块是通过数据流图模块是通过数据流图模块是通过数据流图模块是通过数据流图来定义的。来定义的。来定义的。来定义的。(4)(4)过程内聚(过程内聚(Procedural CohesionProcedural Cohesion)模块内各处理成分相关,且必须以特定次序执行模块内各处理成分相关,且必须以特定次序执行读入读入成绩单成绩单审查审查成绩单成绩单统计统计成绩成绩打印打印成绩成绩读入并审查读入并审查成绩单成绩单统计并打印统计并打印成绩单成绩单(5)(5)时间内聚(时间内聚(Classical CohesionClassical

38、 Cohesion)时间内聚又称为经典内聚。这种模块大多时间内聚又称为经典内聚。这种模块大多为多功能模块,但模块的各个功能的执行为多功能模块,但模块的各个功能的执行与时间有关,通常要求所有功能必须在同与时间有关,通常要求所有功能必须在同一时间段内执行。一时间段内执行。例如初始化模块和终止模块例如初始化模块和终止模块,系统结束模块、系统结束模块、紧急故障处理模块等均是时间性聚合模块紧急故障处理模块等均是时间性聚合模块 。(6)(6)逻辑内聚(逻辑内聚(Logical CohesionLogical Cohesion)把几种相关功能把几种相关功能(逻辑上相似的功能逻辑上相似的功能)组合组合在一模块

39、内在一模块内,每次调用由传给模块的参数确每次调用由传给模块的参数确定执行哪种功能。定执行哪种功能。SXYZWABCDSXYZW ABCD(7)(7)(7)(7)巧合内聚(巧合内聚(巧合内聚(巧合内聚(Coincidental CohesionCoincidental CohesionCoincidental CohesionCoincidental Cohesion)当模块内各部分之当模块内各部分之当模块内各部分之当模块内各部分之间没有联系,或者间没有联系,或者间没有联系,或者间没有联系,或者即使有联系,这种即使有联系,这种即使有联系,这种即使有联系,这种联也很松散,则称联也很松散,则称联也很

40、松散,则称联也很松散,则称这种模块为巧合内这种模块为巧合内这种模块为巧合内这种模块为巧合内聚模块,它是内聚聚模块,它是内聚聚模块,它是内聚聚模块,它是内聚程度最低的模块。程度最低的模块。程度最低的模块。程度最低的模块。模块模块MM中的三个语句没有任何联系中的三个语句没有任何联系缺点:可理解性差,缺点:可理解性差,可修改性差可修改性差内聚与耦合密切相关,同其它模块强耦合的内聚与耦合密切相关,同其它模块强耦合的模块意味者弱内聚,强内聚模块意味着与其模块意味者弱内聚,强内聚模块意味着与其它模块间松散耦合它模块间松散耦合。设计目标:设计目标:力争强内聚、弱耦合力争强内聚、弱耦合耦合、内聚与模块独立性关

41、系:耦合、内聚与模块独立性关系:耦合与内聚都是模块独立性的定性标准,都反映模耦合与内聚都是模块独立性的定性标准,都反映模块独立性的良好程度。但耦合是直接的主导因素,块独立性的良好程度。但耦合是直接的主导因素,内聚则辅助耦合共同对模块独立性进行衡量。内聚则辅助耦合共同对模块独立性进行衡量。4.3 4.3 启发规则启发规则1.1.改进软件结构提高模块独立性。改进软件结构提高模块独立性。2.2.模块规模应该适中。模块规模应该适中。3.3.深度、宽度、扇出和扇入都应适当。深度、宽度、扇出和扇入都应适当。4.4.模块的作用域应该在控制域之内。模块的作用域应该在控制域之内。5.5.力争降低模块接口的复杂程

42、度。力争降低模块接口的复杂程度。6.6.设计单入口单出口的模块。设计单入口单出口的模块。7.7.模块功能应该可以预测。模块功能应该可以预测。4.4 4.4 软件设计过程软件设计过程1.1.1.1.制定规范制定规范制定规范制定规范 在进入软件开发阶段之初,在进入软件开发阶段之初,在进入软件开发阶段之初,在进入软件开发阶段之初,首先应为软件开发组制定首先应为软件开发组制定首先应为软件开发组制定首先应为软件开发组制定在设计时应该共同遵守的在设计时应该共同遵守的在设计时应该共同遵守的在设计时应该共同遵守的标准,以便协调组内各成标准,以便协调组内各成标准,以便协调组内各成标准,以便协调组内各成员的工作。

43、包括员的工作。包括员的工作。包括员的工作。包括:-阅读和理解软件需求说明书,确阅读和理解软件需求说明书,确阅读和理解软件需求说明书,确阅读和理解软件需求说明书,确认用户要求能否实现,明确实现认用户要求能否实现,明确实现认用户要求能否实现,明确实现认用户要求能否实现,明确实现的条件,从而确定设计的目标,的条件,从而确定设计的目标,的条件,从而确定设计的目标,的条件,从而确定设计的目标,以及它们的优先顺序以及它们的优先顺序以及它们的优先顺序以及它们的优先顺序 -根据目标确定最合适的设计方法根据目标确定最合适的设计方法根据目标确定最合适的设计方法根据目标确定最合适的设计方法 -规定设计文档的编制标准

44、规定设计文档的编制标准规定设计文档的编制标准规定设计文档的编制标准 -规定编码的信息形式,与硬件,规定编码的信息形式,与硬件,规定编码的信息形式,与硬件,规定编码的信息形式,与硬件,操作系统的接口规约,命名规则操作系统的接口规约,命名规则操作系统的接口规约,命名规则操作系统的接口规约,命名规则2.2.2.2.软件系统结构的总体设计软件系统结构的总体设计软件系统结构的总体设计软件系统结构的总体设计 基于功能层次结构建立系统基于功能层次结构建立系统基于功能层次结构建立系统基于功能层次结构建立系统 -采用某种设计方法,将系统按采用某种设计方法,将系统按采用某种设计方法,将系统按采用某种设计方法,将系

45、统按功能划分成模块的层次结构功能划分成模块的层次结构功能划分成模块的层次结构功能划分成模块的层次结构 -确定每个模块的功能确定每个模块的功能确定每个模块的功能确定每个模块的功能 -建立与已确定的软件需求的对建立与已确定的软件需求的对建立与已确定的软件需求的对建立与已确定的软件需求的对应关系应关系应关系应关系 -确定模块间的调用关系确定模块间的调用关系确定模块间的调用关系确定模块间的调用关系 -确定模块间的接口确定模块间的接口确定模块间的接口确定模块间的接口 -评估模块划分的质量评估模块划分的质量评估模块划分的质量评估模块划分的质量4.4 4.4 软件设计过程软件设计过程3.3.3.3.处理方式

46、设计处理方式设计处理方式设计处理方式设计 确定为实现系统的功能需确定为实现系统的功能需确定为实现系统的功能需确定为实现系统的功能需求所必需的算法,评估算求所必需的算法,评估算求所必需的算法,评估算求所必需的算法,评估算法的性能法的性能法的性能法的性能 确定为满足系统的性能需确定为满足系统的性能需确定为满足系统的性能需确定为满足系统的性能需求所必需的算法和模块间求所必需的算法和模块间求所必需的算法和模块间求所必需的算法和模块间的控制方式的控制方式的控制方式的控制方式 周转时间周转时间周转时间周转时间 响应时间响应时间响应时间响应时间 吞吐量吞吐量吞吐量吞吐量 精度精度精度精度 确定外部信号的接收

47、发送确定外部信号的接收发送确定外部信号的接收发送确定外部信号的接收发送形式形式形式形式4.4.4.4.数据结构设计数据结构设计数据结构设计数据结构设计 确定软件涉及的文件系统的确定软件涉及的文件系统的确定软件涉及的文件系统的确定软件涉及的文件系统的结构以及数据库的模式、子结构以及数据库的模式、子结构以及数据库的模式、子结构以及数据库的模式、子模式,进行数据完整性和安模式,进行数据完整性和安模式,进行数据完整性和安模式,进行数据完整性和安全性的设计全性的设计全性的设计全性的设计 确定输入,输出文件的详细确定输入,输出文件的详细确定输入,输出文件的详细确定输入,输出文件的详细的数据结构的数据结构的

48、数据结构的数据结构 结合算法设计,确定算法所结合算法设计,确定算法所结合算法设计,确定算法所结合算法设计,确定算法所必需的逻辑数据结构及其操必需的逻辑数据结构及其操必需的逻辑数据结构及其操必需的逻辑数据结构及其操作作作作 确定对逻辑数据结构所必需确定对逻辑数据结构所必需确定对逻辑数据结构所必需确定对逻辑数据结构所必需的那些操作的程序模块的那些操作的程序模块的那些操作的程序模块的那些操作的程序模块(软件软件软件软件包包包包)4.4 4.4 软件设计过程软件设计过程4.4.4.4.数据结构设计(续)数据结构设计(续)数据结构设计(续)数据结构设计(续)限制和确定各个数据设计限制和确定各个数据设计限

49、制和确定各个数据设计限制和确定各个数据设计决策的影响范围决策的影响范围决策的影响范围决策的影响范围 若需要与操作系统或调度若需要与操作系统或调度若需要与操作系统或调度若需要与操作系统或调度程序接口所必须的控制表程序接口所必须的控制表程序接口所必须的控制表程序接口所必须的控制表等数据时,确定其详细的等数据时,确定其详细的等数据时,确定其详细的等数据时,确定其详细的数据结构和使用规则数据结构和使用规则数据结构和使用规则数据结构和使用规则 数据的保护性设计数据的保护性设计数据的保护性设计数据的保护性设计防卫性设计:在软件设防卫性设计:在软件设防卫性设计:在软件设防卫性设计:在软件设计中就插入自动检错

50、,计中就插入自动检错,计中就插入自动检错,计中就插入自动检错,报错和纠错的功能报错和纠错的功能报错和纠错的功能报错和纠错的功能 一致性设计:一致性设计:一致性设计:一致性设计:保证软件运行过程中所使用保证软件运行过程中所使用保证软件运行过程中所使用保证软件运行过程中所使用的数据的类型和取值范围不的数据的类型和取值范围不的数据的类型和取值范围不的数据的类型和取值范围不变变变变在并发处理过程中使用封锁在并发处理过程中使用封锁在并发处理过程中使用封锁在并发处理过程中使用封锁和解除封锁机制保持数据不和解除封锁机制保持数据不和解除封锁机制保持数据不和解除封锁机制保持数据不被破坏被破坏被破坏被破坏 冗余性

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 生活常识

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁