软件设计基本概念课件.ppt

上传人(卖家):晟晟文业 文档编号:5222516 上传时间:2023-02-17 格式:PPT 页数:72 大小:782.38KB
下载 相关 举报
软件设计基本概念课件.ppt_第1页
第1页 / 共72页
软件设计基本概念课件.ppt_第2页
第2页 / 共72页
软件设计基本概念课件.ppt_第3页
第3页 / 共72页
软件设计基本概念课件.ppt_第4页
第4页 / 共72页
软件设计基本概念课件.ppt_第5页
第5页 / 共72页
点击查看更多>>
资源描述

1、第第2 2章章 软件设计基本概念软件设计基本概念2.1 2.1 设计过程设计过程2.2 2.2 设计原理设计原理2.3 2.3 启发规则启发规则软件设计宣言:软件设计宣言:Mitch KaporMitch Kaporn“什么是设计?设计是你站在两个世界什么是设计?设计是你站在两个世界技技术世界和人类的目标世界术世界和人类的目标世界而你尝试将这两而你尝试将这两个世界结合在一起个世界结合在一起”。罗马建筑批评家罗马建筑批评家VitruviusVitruvius提出的观念:提出的观念:n“设计良好的建筑应该展示出坚固、适用和令设计良好的建筑应该展示出坚固、适用和令人赏心悦目人赏心悦目”。设计阶段:设

2、计阶段:n从工程管理的角度,可以将软件设计分为概要从工程管理的角度,可以将软件设计分为概要设计阶段和详细设计阶段。设计阶段和详细设计阶段。n从技术的角度,传统的结构化方法将软件设计从技术的角度,传统的结构化方法将软件设计划分为体系结构设计、数据设计、接口设计和划分为体系结构设计、数据设计、接口设计和过程设计过程设计4 4部分。部分。n面向对象方法则将软件设计划分为体系结构设面向对象方法则将软件设计划分为体系结构设计、类设计计、类设计/数据设计、接口设计和构件级设数据设计、接口设计和构件级设计计4 4部分。部分。结构化设计和结构化分析的关系:结构化设计和结构化分析的关系:n总体设计过程:总体设计

3、过程:首先寻找实现目标系统的各种首先寻找实现目标系统的各种不同的方案;然后分析员从这些供选择的方案不同的方案;然后分析员从这些供选择的方案中选取若干个合理的方案,从中选出一个最佳中选取若干个合理的方案,从中选出一个最佳方案向用户和使用部门负责人推荐;分析员应方案向用户和使用部门负责人推荐;分析员应该进一步为这个最佳方案设计软件结构,进行该进一步为这个最佳方案设计软件结构,进行必要的数据库设计,确定测试要求并且制定测必要的数据库设计,确定测试要求并且制定测试计划。试计划。n必要性:必要性:总体设计可以站在全局高度上,花较总体设计可以站在全局高度上,花较少成本,从较抽象的层次上分析对比多种可能少成

4、本,从较抽象的层次上分析对比多种可能的系统实现方案和软件结构,从中选出最佳方的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。出较高质量的软件系统。5.1 5.1 设计过程设计过程由两个主要阶段组成:由两个主要阶段组成:n系统设计阶段,确定系统的具体实现方案系统设计阶段,确定系统的具体实现方案q设想供选择的方案设想供选择的方案q选取合理的方案选取合理的方案q推荐最佳方案推荐最佳方案n结构设计阶段,确定软件结构结构设计阶段,确定软件结构q功能分解功能分解q设计软件结构设计软件结构q设计数据库设计数据库q制

5、定测试计划制定测试计划q书写文档书写文档q审查和复审审查和复审典型的总体设计过程包括下述典型的总体设计过程包括下述9 9个步骤:个步骤:1.1.设想供选择的方案设想供选择的方案n根据需求分析阶段得出的数据流图考虑各种可根据需求分析阶段得出的数据流图考虑各种可能的实现方案,力求从中选出最佳方案。能的实现方案,力求从中选出最佳方案。2.2.选取合理的方案选取合理的方案n从前一步得到的一系列供选择的方案中选取若从前一步得到的一系列供选择的方案中选取若干个合理的方案。对每个合理的方案分析员都干个合理的方案。对每个合理的方案分析员都应该准备下列应该准备下列4 4份资料:份资料:q系统流程图;系统流程图;

6、q组成系统的物理元素清单;组成系统的物理元素清单;q成本成本/效益分析;效益分析;q实现这个系统的进度计划。实现这个系统的进度计划。3.3.推荐最佳方案推荐最佳方案n分析员应该综合分析对比各种合理方案的利弊分析员应该综合分析对比各种合理方案的利弊,推荐一个最佳的方案,并且为推荐的方案制,推荐一个最佳的方案,并且为推荐的方案制定详细的实现计划。定详细的实现计划。4.4.功能分解功能分解n首先进行结构设计,然后进行过程设计。首先进行结构设计,然后进行过程设计。n结构设计确定程序由哪些模块组成,以及这些结构设计确定程序由哪些模块组成,以及这些模块之间的关系;过程设计确定每个模块的处模块之间的关系;过

7、程设计确定每个模块的处理过程。理过程。n结构设计是总体设计阶段的任务,过程设计是结构设计是总体设计阶段的任务,过程设计是详细设计阶段的任务。详细设计阶段的任务。5.5.设计软件结构设计软件结构n通常程序中的一个模块完成一个适当的子功能通常程序中的一个模块完成一个适当的子功能。应该把模块组织成良好的层次系统。软件结。应该把模块组织成良好的层次系统。软件结构可以用层次图或结构图来描绘。构可以用层次图或结构图来描绘。n如果数据流图已经细化到适当的层次,则可以如果数据流图已经细化到适当的层次,则可以直接从数据流图映射出软件结构,这就是面向直接从数据流图映射出软件结构,这就是面向数据流的设计方法。数据流

8、的设计方法。6.6.设计数据库设计数据库n对于需要使用数据库的那些应用系统,软件工对于需要使用数据库的那些应用系统,软件工程师应该在需求分析阶段所确定的系统数据需程师应该在需求分析阶段所确定的系统数据需求的基础上,进一步设计数据库。求的基础上,进一步设计数据库。7.7.制定测试计划制定测试计划n在软件开发的早期阶段考虑测试问题,能促使软件设在软件开发的早期阶段考虑测试问题,能促使软件设计人员在设计时注意提高软件的可测试性。计人员在设计时注意提高软件的可测试性。8.8.书写文档书写文档n应该用正式的文档记录总体设计的结果,在这个阶段应该用正式的文档记录总体设计的结果,在这个阶段应该完成的文档通常

9、有下述几种:应该完成的文档通常有下述几种:(1)(1)系统说明;系统说明;(2)(2)用户手册;用户手册;(3)(3)测试测试计划;计划;(4)(4)详细的实现计划;详细的实现计划;(5)(5)数据库设计结数据库设计结果。果。9.9.审查和复审审查和复审n最后应该对总体设计的结果进行严格的技术审查和管最后应该对总体设计的结果进行严格的技术审查和管理复审。理复审。5.2 5.2 设计原理设计原理5.2.1 5.2.1 模块化模块化n模块:模块:是由边界元素限定的相邻程序元素的序是由边界元素限定的相邻程序元素的序列,而且有一个总体标识符代表它。列,而且有一个总体标识符代表它。n模块化:模块化:就是

10、把程序划分成独立命名且可独立就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。的功能满足用户的需求。为什么要模块化?为什么要模块化?n模块化是为了使一个复杂的大型程序能被人的模块化是为了使一个复杂的大型程序能被人的智力所管理,软件应该具备的惟一属性。智力所管理,软件应该具备的惟一属性。n如果一个大型程序仅由一个模块组成,它将很如果一个大型程序仅由一个模块组成,它将很难被人所理解。难被人所理解。模块化的根据:模块化的根据:n如果如果C

11、(C(P P1)C(1)C(P P2)2),显然,显然E(P1)E(P2)E(P1)E(P2)n根据人类解决一般问题的经验,根据人类解决一般问题的经验,C(C(P P1+1+P P2)C(2)C(P P1)+C(1)+C(P P2)2)n综上所述,得到下面的不等式综上所述,得到下面的不等式E(E(P P1+1+P P2)E(2)E(P P1)+E(1)+E(P P2)2)n每个程序都相每个程序都相应地有一个最应地有一个最适当的模块数适当的模块数目目M M,使得系统,使得系统的开发成本最的开发成本最小。小。模块化和软件成本模块化和软件成本模块化的作用:模块化的作用:n采用模块化原理可以使软件结构

12、清晰,不仅容采用模块化原理可以使软件结构清晰,不仅容易设计也容易阅读和理解。易设计也容易阅读和理解。n模块化使软件容易测试和调试,因而有助于提模块化使软件容易测试和调试,因而有助于提高软件的可靠性。高软件的可靠性。n模块化能够提高软件的可修改性。模块化能够提高软件的可修改性。n模块化也有助于软件开发工程的组织管理。模块化也有助于软件开发工程的组织管理。5.2.2 5.2.2 抽象抽象n抽象:抽象:现实世界中一定事物、状态或过程之间现实世界中一定事物、状态或过程之间总存在着某些相似的方面总存在着某些相似的方面(共性共性)。把这些相似。把这些相似的方面集中和概括起来,暂时忽略它们之间的的方面集中和

13、概括起来,暂时忽略它们之间的差异,这就是抽象。差异,这就是抽象。n抽象就是抽出事物本质特性而暂时不考虑细节抽象就是抽出事物本质特性而暂时不考虑细节。n“抽象是人类处理复杂问题的基本方法之一。抽象是人类处理复杂问题的基本方法之一。”Grady BoachGrady Boach一般抽象过程:一般抽象过程:n处理复杂系统的惟一有效的方法是用层次的方处理复杂系统的惟一有效的方法是用层次的方式构造和分析它。式构造和分析它。n一个复杂的动态系统首先可以用一些高级的抽一个复杂的动态系统首先可以用一些高级的抽象概念构造和理解,这些高级概念又可以用一象概念构造和理解,这些高级概念又可以用一些较低级的概念构造和理

14、解,如此进行下去,些较低级的概念构造和理解,如此进行下去,直至最低层次的具体元素。直至最低层次的具体元素。n例:过程抽象、数据抽象例:过程抽象、数据抽象开开(行为抽象)行为抽象)+门门(数据抽象数据抽象)形体形体衣着衣着性格性格抽象抽象抽象例子外表外表软件工程抽象过程:软件工程抽象过程:n软件工程过程的每一步都是对软件解法的抽象软件工程过程的每一步都是对软件解法的抽象层次的一次精化。层次的一次精化。n在可行性研究阶段,软件作为系统的一个完整在可行性研究阶段,软件作为系统的一个完整部件;部件;n在需求分析期间,软件解法是使用在问题环境在需求分析期间,软件解法是使用在问题环境内熟悉的方式描述的;内

15、熟悉的方式描述的;n当由总体设计向详细设计过渡时,抽象的程度当由总体设计向详细设计过渡时,抽象的程度也就随之减少了;也就随之减少了;n最后,当源程序写出来以后,也就达到了抽象最后,当源程序写出来以后,也就达到了抽象的最低层。的最低层。5.2.3 5.2.3 逐步求精逐步求精n逐步求精:逐步求精:为了能集中精力解决主要问题而尽为了能集中精力解决主要问题而尽量推迟对问题细节的考虑。逐步求精是人类解量推迟对问题细节的考虑。逐步求精是人类解决复杂问题时采用的基本方法,也是许多软件决复杂问题时采用的基本方法,也是许多软件工程技术的基础。工程技术的基础。nMillerMiller法则:一个人在任何时候都只

16、能把注意法则:一个人在任何时候都只能把注意力集中在(力集中在(7 72 2)个知识块上。)个知识块上。逐步求精逐步求精外表外表形体形体衣着衣着性格性格头发头发脸形脸形领带领带抽象抽象逐步求精的例子例:例:用筛选法求用筛选法求100100以内的素数。所谓的筛选法,就是以内的素数。所谓的筛选法,就是从从2 2到到100100中去掉中去掉2 2,3 3,5 5,7 7的倍数,剩下的就是的倍数,剩下的就是100100以内的素数。以内的素数。n首先按程序功能写出一个框架首先按程序功能写出一个框架main()main()建立建立2 2到到100100的数组的数组A A,其中,其中AiAii i;.1.1

17、建立建立2 2到到1010的素数表的素数表B B,存放,存放2 2到到1010以内的素数;以内的素数;.2.2 若若AiAii i是是B B 中任一数的倍数,则剔除中任一数的倍数,则剔除AiAi;.3.3 输出输出A A 中所有没有被剔除的数;中所有没有被剔除的数;.4.4 n上述框架中每一个加工语句都可进一步细化上述框架中每一个加工语句都可进一步细化nmain()main()/*建立建立2 2到到100100的数组的数组A A,其中,其中AiAii i*/.1.1 for for(i=2i=2;i=100i=100;i+i+)Ai=iAi=i;/*建立建立2 2到到1010的素数表的素数表B

18、 B,存放,存放2 2到到1010以内的素数以内的素数*/.2.2 B1=2 B1=2;B2=3B2=3;B3=5B3=5;B4=7B4=7;/*若若AiAii i是是B B 中任一数的倍数,则剔除中任一数的倍数,则剔除AiAi*/.3.3 for for(j=1j=1;j=4j=4;j+j+)检查检查AA所有数能否被所有数能否被BjBj整除并将其从整除并将其从AA剔除;剔除;.3.1.3.1 /*输出输出A A 中所有没有被剔除的数中所有没有被剔除的数*/.4.4 for for(i=2i=2;i=100i 25)if(argument_xyz25)module_3();module_3()

19、;else else module_4();module_4();评价:评价:n与结构化编程矛盾,生成的代码完全不可读。与结构化编程矛盾,生成的代码完全不可读。n如果在一个模块中对一个全局变量的声明进行修改,如果在一个模块中对一个全局变量的声明进行修改,必须修改能够访问该全局变量的每一个模块。必须修改能够访问该全局变量的每一个模块。n公共环境耦合的模块难于重用,必须提供一个全局变公共环境耦合的模块难于重用,必须提供一个全局变量的清单。量的清单。n即使模块本身不改变,它和产品中其他模块之间公共即使模块本身不改变,它和产品中其他模块之间公共环境耦合的实例数也会变化非常大。环境耦合的实例数也会变化非

20、常大。n潜在危险很大。模块暴露出必需要更多的数据,难以潜在危险很大。模块暴露出必需要更多的数据,难以控制数据存取,而且会导致计算机犯罪。控制数据存取,而且会导致计算机犯罪。n有些情况下公共环境耦合更好。有些情况下公共环境耦合更好。函数可重入的概念n可重入函数也可以这样理解,重入即表示重复进入,首先可重入函数也可以这样理解,重入即表示重复进入,首先它意味着这个函数可以被中断,其次意味着它除了使用自它意味着这个函数可以被中断,其次意味着它除了使用自己栈上的己栈上的变量变量以外不依赖于任何环境(包括以外不依赖于任何环境(包括staticstatic),这),这样的函数就是样的函数就是purecode

21、purecode(纯代码纯代码)可重入,可以允许有该)可重入,可以允许有该函数的多个副本在运行,由于它们使用的是分离的栈,所函数的多个副本在运行,由于它们使用的是分离的栈,所以不会互相干扰。如果确实需要访问以不会互相干扰。如果确实需要访问全局变量全局变量(包括(包括staticstatic),一定要注意实施互斥手段。可重入函数在并行),一定要注意实施互斥手段。可重入函数在并行运行环境中非常重要,但是一般要为访问全局变量付出一运行环境中非常重要,但是一般要为访问全局变量付出一些性能代价些性能代价(6)(6)内容耦合内容耦合(content coupling)(content coupling)n

22、最高程度的耦合是内容耦合。如果出现下列最高程度的耦合是内容耦合。如果出现下列情况之一,两个模块间就发生了内容耦合:情况之一,两个模块间就发生了内容耦合:q一个模块访问另一个模块的内部数据;一个模块访问另一个模块的内部数据;q一个模块不通过正常入口转到另一个模块的内部一个模块不通过正常入口转到另一个模块的内部;q两个模块有一部分程序代码重叠;两个模块有一部分程序代码重叠;q一个模块有多个入口。一个模块有多个入口。n耦合是影响软件复杂程度的一个重要因素。耦合是影响软件复杂程度的一个重要因素。n应该采取下述设计原则:应该采取下述设计原则:尽量使用数据耦合,尽量使用数据耦合,少用控制耦合和特征耦合,少

23、用控制耦合和特征耦合,限制公共环境耦合的范围,限制公共环境耦合的范围,完全不用内容耦合。完全不用内容耦合。2.2.内聚内聚n内聚:内聚:标志一个模块内各个元素彼此结合的紧标志一个模块内各个元素彼此结合的紧密程度,它是信息隐藏和局部化概念的自然扩密程度,它是信息隐藏和局部化概念的自然扩展。简单地说,理想内聚的模块只做一件事情展。简单地说,理想内聚的模块只做一件事情。n要求:要求:设计时应该力求做到高内聚,通常中等设计时应该力求做到高内聚,通常中等程度的内聚也是可以采用的,而且效果和高内程度的内聚也是可以采用的,而且效果和高内聚相差不多;但是,低内聚不要使用。聚相差不多;但是,低内聚不要使用。n内

24、聚和耦合是密切相关的,模块内的高内聚往内聚和耦合是密切相关的,模块内的高内聚往往意味着模块间的松耦合。实践表明内聚更重往意味着模块间的松耦合。实践表明内聚更重要,应该把更多注意力集中到提高模块的内聚要,应该把更多注意力集中到提高模块的内聚程度上。程度上。内聚程度的度量:内聚程度的度量:(1)(1)偶然内聚偶然内聚(coincidental cohesion)(coincidental cohesion)n如果一个模块完成一组任务,这些任务彼此间如果一个模块完成一组任务,这些任务彼此间即使有关系,关系也是很松散的,就叫做偶然即使有关系,关系也是很松散的,就叫做偶然内聚。内聚。MA=B+CGET

25、CHERIF R=5 THEN S=1评价:评价:n模块内各元素之间没有实质性联系,很可能在模块内各元素之间没有实质性联系,很可能在一种应用场合需要修改这个模块,在另一种应一种应用场合需要修改这个模块,在另一种应用场合又不允许这种修改,从而陷入困境;用场合又不允许这种修改,从而陷入困境;n可理解性差,可维护性产生退化;可理解性差,可维护性产生退化;n模块是不可重用的。模块是不可重用的。解决方案:解决方案:n将模块分成更小的模块,每个小模块执行一个将模块分成更小的模块,每个小模块执行一个操作。操作。(2)(2)逻辑内聚逻辑内聚(logical cohesion)(logical cohesion

26、)n如果一个模块完成的任务在逻辑上属于相同如果一个模块完成的任务在逻辑上属于相同或相似的一类,则称为逻辑内聚。或相似的一类,则称为逻辑内聚。评价:评价:n接口难以理解,造成整体上不易理解;接口难以理解,造成整体上不易理解;n完成多个操作的代码互相纠缠在一起,即使局完成多个操作的代码互相纠缠在一起,即使局部功能的修改有时也会影响全局,导致严重的部功能的修改有时也会影响全局,导致严重的维护问题;维护问题;n难以重用。难以重用。解决方案:解决方案:n模块分解。模块分解。(3)(3)时间内聚时间内聚(temporal cohesion)(temporal cohesion)n如果一个模块包含的任务必须

27、在同一段时间如果一个模块包含的任务必须在同一段时间内执行,就叫时间内聚。内执行,就叫时间内聚。执行初始化执行初始化打开旧主文件、新主文件、事务文件和打印文件;打开旧主文件、新主文件、事务文件和打印文件;初始化销售地区表;初始化销售地区表;读第一条事务记录和第一条旧主文件记录;读第一条事务记录和第一条旧主文件记录;评价:评价:n时间关系在一定程度上反映了程序某些实质,时间关系在一定程度上反映了程序某些实质,所以时间内聚比逻辑内聚好一些。所以时间内聚比逻辑内聚好一些。n模块内操作之间的关系很弱,与其他模块的操模块内操作之间的关系很弱,与其他模块的操作却有很强的关联。作却有很强的关联。n时间内聚的模

28、块不太可能重用。时间内聚的模块不太可能重用。(4)(4)过程内聚过程内聚(procedural cohesion)(procedural cohesion)n如果一个模块内的处理元素是相关的,而且必如果一个模块内的处理元素是相关的,而且必须以特定次序执行,则称为过程内聚。须以特定次序执行,则称为过程内聚。n使用程序流程图作为工具设计软件时,常常通使用程序流程图作为工具设计软件时,常常通过研究流程图确定模块的划分,这样得到的往过研究流程图确定模块的划分,这样得到的往往是过程内聚的模块。往是过程内聚的模块。评价:评价:n比时间内聚好,至少操作之间是过程关联的。比时间内聚好,至少操作之间是过程关联的

29、。n仍是弱连接,不太可能重用模块。仍是弱连接,不太可能重用模块。解决方案:解决方案:n分割为单独的模块,每个模块执行一个操作。分割为单独的模块,每个模块执行一个操作。(5)(5)通信内聚通信内聚(communicational cohesion)(communicational cohesion)n如果模块中所有元素都使用同一个输入数据如果模块中所有元素都使用同一个输入数据和和(或或)产生同一个输出数据,则称为通信内产生同一个输出数据,则称为通信内聚。即在同一个数据结构上操作。聚。即在同一个数据结构上操作。评价:评价:n模块中各操作紧密相连,比过程内聚更好。模块中各操作紧密相连,比过程内聚更好

30、。n不能重用。不能重用。解决方案:解决方案:n分成多个模块,每个模块执行一个操作。分成多个模块,每个模块执行一个操作。(6)(6)顺序内聚顺序内聚(sequential cohesion)(sequential cohesion)n如果一个模块内的处理元素和同一个功能密如果一个模块内的处理元素和同一个功能密切相关,而且这些处理必须顺序执行,则称切相关,而且这些处理必须顺序执行,则称为顺序内聚。为顺序内聚。评价:评价:n根据数据流图划分模块时,通常得到顺序内根据数据流图划分模块时,通常得到顺序内聚的模块,这种模块彼此间的连接往往比较聚的模块,这种模块彼此间的连接往往比较简单。简单。(7)(7)功

31、能内聚功能内聚(functional cohesion)(functional cohesion)n如果模块内所有处理元素属于一个整体,完如果模块内所有处理元素属于一个整体,完成一个单一的功能,则称为功能内聚。功能成一个单一的功能,则称为功能内聚。功能内聚是最高程度的内聚。内聚是最高程度的内聚。评价:评价:n模块可重用,应尽可能重用;模块可重用,应尽可能重用;n可隔离错误,维护更容易;可隔离错误,维护更容易;n扩充产品功能时更容易。扩充产品功能时更容易。七种内聚的优劣评分结果:七种内聚的优劣评分结果:n高内聚:功能内聚高内聚:功能内聚 1010分分 顺序内聚顺序内聚 9 9分分n中内聚:通信内

32、聚中内聚:通信内聚 7 7分分 过程内聚过程内聚 5 5分分n低内聚:时间内聚低内聚:时间内聚 3 3分分 逻辑内聚逻辑内聚 1 1分分 偶然内聚偶然内聚 0 0分分n设计时力争做到高内聚,并且能够辨认出低内设计时力争做到高内聚,并且能够辨认出低内聚的模块。聚的模块。5.3 5.3 启发规则启发规则1.1.改进软件结构提高模块独立性改进软件结构提高模块独立性n通过模块分解或合并,降低耦合提高内聚。通过模块分解或合并,降低耦合提高内聚。n两个方面:两个方面:q模块功能完善化。一个完整的模块包含:模块功能完善化。一个完整的模块包含:n执行规定的功能的部分执行规定的功能的部分n出错处理的部分出错处理

33、的部分n返回一个返回一个“结束标志结束标志”q消除重复功能,改善软件结构。消除重复功能,改善软件结构。n完全相似完全相似n局部相似局部相似2.2.模块规模应该适中模块规模应该适中n经验表明,一个模块的规模不应过大,最好能经验表明,一个模块的规模不应过大,最好能写在一页纸内。通常规定写在一页纸内。通常规定5010050100行语句,最多行语句,最多不超过不超过500500行。数字只能作为参考,根本问题行。数字只能作为参考,根本问题是要保证模块的独立性。是要保证模块的独立性。n过大的模块往往是由于分解不充分,但是进一过大的模块往往是由于分解不充分,但是进一步分解必须符合问题结构,一般说来,分解后步

34、分解必须符合问题结构,一般说来,分解后不应该降低模块独立性。不应该降低模块独立性。n过小的模块开销大于有效操作,而且模块数目过小的模块开销大于有效操作,而且模块数目过多将使系统接口复杂。过多将使系统接口复杂。3.3.深度、宽度、扇出和扇入都应适当深度、宽度、扇出和扇入都应适当n深度:深度:软件结构中控制的层数,它往往能粗略软件结构中控制的层数,它往往能粗略地标志一个系统的大小和复杂程度。地标志一个系统的大小和复杂程度。n宽度:宽度:软件结构内同一个层次上的模块总数的软件结构内同一个层次上的模块总数的最大值。最大值。n扇出:扇出:一个模块直接控制一个模块直接控制(调用调用)的模块数目。的模块数目

35、。n扇入:扇入:有多少个上级模块直接调用它。有多少个上级模块直接调用它。4.4.模块的作用域应该在控制域之内模块的作用域应该在控制域之内n模块的作用域:模块的作用域:定义为受该模块内一个判定影定义为受该模块内一个判定影响的所有模块的集合。响的所有模块的集合。n模块的控制域:模块的控制域:是这个模块本身以及所有直接是这个模块本身以及所有直接或间接从属于它的模块的集合。或间接从属于它的模块的集合。n在一个设计得很好的系统中,所有受判定影响在一个设计得很好的系统中,所有受判定影响的模块应该都从属于做出判定的那个模块,最的模块应该都从属于做出判定的那个模块,最好局限于做出判定的那个模块本身及它的直属好

36、局限于做出判定的那个模块本身及它的直属下级模块。下级模块。解决方案:解决方案:n把模块把模块A A中的判定移到模块中的判定移到模块M M中;中;n把模块把模块G G移到模块移到模块A A下面,作为他的下级模块。下面,作为他的下级模块。5.5.力争降低模块接口的复杂程度力争降低模块接口的复杂程度n模块接口复杂是软件发生错误的一个主要原因模块接口复杂是软件发生错误的一个主要原因。应该仔细设计模块接口,使得信息传递简单。应该仔细设计模块接口,使得信息传递简单并且和模块的功能一致。并且和模块的功能一致。例:解一元二次方程的函数例:解一元二次方程的函数nQUAD_ROOT(TBL,X)QUAD_ROOT

37、(TBL,X)q其中数组其中数组TBLTBL传送方程的系数传送方程的系数q数组数组X X送回求得的根送回求得的根nQUAD_ROOT(A,B,C,ROOT1,ROOT2)QUAD_ROOT(A,B,C,ROOT1,ROOT2)6.6.设计单入口单出口的模块设计单入口单出口的模块n警告软件工程师不要使模块间出现内容耦合。警告软件工程师不要使模块间出现内容耦合。当从顶部进入模块并且从底部退出来时,软件当从顶部进入模块并且从底部退出来时,软件是比较容易理解的,因此也是比较容易维护的是比较容易理解的,因此也是比较容易维护的。7.7.模块功能应该可以预测模块功能应该可以预测n模块的功能应该能够预测,但也要防止模块功模块的功能应该能够预测,但也要防止模块功能过分局限。能过分局限。n功能可预测:功能可预测:如果一个模块可以当做一个黑盒如果一个模块可以当做一个黑盒子,只要输入的数据相同就产生同样的输出,子,只要输入的数据相同就产生同样的输出,这个模块的功能就是可以预测的。这个模块的功能就是可以预测的。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

1,本文(软件设计基本概念课件.ppt)为本站会员(晟晟文业)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|