第5章-总体设计.ppt

  1. 1、本文档共93页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

软件工程计算机与信息科学学院曹严元cookie5@swu.edu.cn第1章软件工程学概述第2章可行性研究第3章需求分析第4章形式化说明技术第5章总体设计第6章详细设计第7章实现第8章维护第9章面向对象方法学引论第10章面向对象分析第11章面向对象设计第12章面向对象实现第13章软件项目管理第5章总体设计总体设计又称为概要设计或初步设计,总体设计的基本目的就是回答“概括地说,系统应该如何实现?”这个问题。这个阶段的两个重要任务:划分出组成系统的物理元素;设计软件的结构,也就是确定系统中每个程序是由哪些模块组成的,以及这些模块相互间的关系。教学内容5.1设计过程5.2设计原理5.3启发规则5.4描绘软件结构的图形工具5.5面向数据流的设计方法5.1设计过程总体设计过程通常由两个主要阶段组成:系统设计阶段,确定系统的具体实现方案;结构设计阶段,确定软件结构。总体设计的9个步骤:设想供选择的方案以需求分析阶段得出的数据流图为出发点,用划分自动化边界的方法,得到不同的系统实现方案,排除不可行的方案,得到可供选择的方案。选取合理方案从可供选择的方案中选取低成本、中等成本和高成本的三种方案,分析员对每种方案都准备下列4份资料:(1)系统流程图;(2)组成系统的物理元素清单;(3)成本/效益分析;(4)实现这个系统的进度计划。推荐最佳方案分析员应该综合分析对比各种合理方案的利弊,推荐一个最佳的方案,并且为推荐的方案制定详细的实现计划;用户和有关技术专家审查分析员所推荐的最佳系统;使用部门负责人进一步审批;在使用部门的负责人也接受了分析员所推荐的方案之后,将进入总体设计过程的下一个重要阶段——结构设计。功能分解目标系统的实现通常分为两个阶段完成:首先进行结构设计,确定程序由哪些模块组成,以及这些模块之间的关系,结构设计是总体设计阶段的任务;然后进行过程设计,确定每个模块的处理过程。过程设计是详细设计阶段的任务。为确定软件结构,首先需要从实现角度把复杂的功能进一步分解,功能分解导致数据流图的进一步细化,经过分解之后应该使每个功能对大多数程序员而言都是明显易懂的。设计软件结构通常程序中的一个模块完成一个适当的子功能。把这些模块自顶向下组成一种良好的层次调用关系,也就完成了软件结构设计的任务。如果数据流图已经细化到适当的层次,则可以直接从数据流图映射出软件结构。设计数据库对于需要使用数据库的那些应用系统,软件工程师应该在需求分析阶段所确定的系统数据需求的基础上,进一步设计数据库。制定测试计划在软件开发的早期阶段考虑测试问题,能促使软件设计人员在设计时注意提高软件的可测试性。书写文档总体设计阶段应该完成的文档包括:系统说明:主要包括系统流程图、组成系统的物理元素清单、成本/效益分析、对最佳方案的概括描述、精化的数据流图、用层次图或结构图描绘的软件结构、用IPO图描述的各个模块的算法、模块间的接口关系、需求、功能和模块三者之间的交叉参照关系等。用户手册:根据总体设计阶段的结果,修改更正在需求分析阶段产生的初步的用户手册。测试计划详细的实现计划数据库设计结果审查和复审对总体设计的结果进行严格的技术审查,在技术审查通过之后再由使用部门的负责人从管理角度进行复审。5.2设计原理5.2.1模块化5.2.2抽象5.2.3逐步求精5.2.4信息隐藏和局部化5.2.5模块独立5.2.1模块化模块:模块是由边界元素限定的相邻程序元素(例如,数据说明,可执行的语句)的序列,它是单独命名的,并且可以通过名字调用它。模块化:模块化就是把程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。模块化的目的是将系统“分而治之”,模块化能够降低问题的复杂性,使软件结构清晰,易阅读、易理解,易于测试和调试,因而也有助于提高软件的可靠性。模块化的根据设函数C(x)定义问题x的复杂程度,函数E(x)确定解决问题x需要的工作量(时间)。对于两个问题P1和P2,如果C(P1)C(P2)显然E(P1)E(P2)当C(P1+P2)C(P1)+C(P2)则E(P1+P2)E(P1)+E

文档评论(0)

好文精选 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档