- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
软件工程 - 2013 - 第五章 总体设计 第五章总体设计 过去软件设计曾被狭隘地认为是“编程序”或“写代码”,致使软件设计没有发挥它重要的作用,导致软件系统结构稳定性极差; 软件设计是软件开发过程中承前启后的工作,它依据软件需求规格说明书建立软件设计方案,作为下一步程序编码的依据; 是在软件开发中形成质量的地方:设计提供了可用于质量评估的软件表示; 是将需求准确转换为完整的软件产品或系统的唯一办法; 概要设计:将软件需求转化为数据结构和软件的系统结构,即系统的模块划分。 详细设计:通过对系统的结构表示(每个模块的内部工作)进行细化,得到软件的详细的数据结构和算法。 McGlanghlin给出在将需求转换为设计时判断设计好坏的三条特征*: 设计必须实现分析模型中描述的所有显式需求,必须满足用户希望的所有隐式需求。 设计必须是可读、可理解的,使得将来易于编程、易于测试、易于维护。 设计应从实现角度出发,给出与数据、功能、行为相关的软件全貌。 * McGlaughlin, R., “Some Notes on Program Design”, Software Engineering Notes, Vol. 16, no. 4, October 1991, pp. 53-54. 总体设计过程通常由两个主要阶段组成: 系统设计阶段:确定系统的具体实现方案 结构设计阶段:确定软件结构 典型的总体设计过程包括以下9个步骤: 设想供选择的方案: 需求分析阶段得出的数据流图是总体设计的极好的出发点。 设想供选择的方案的一种常用的方法是,设想把数据流图中的处理分组的各种可能的方法,抛弃在技术上行不通的分组方法(例如,组内不同处理的执行时间不相容),余下的分组方法代表可能的实现策略,并且可以启示供选择的物理系统。 选取合理的方案: 从一系列方案中选取若干个合理的方案,通常至少选取低成本、中等成本和高成本的3种方案 对每个合理的方案分析员都应该准备下列4份资料: (1) 系统流程图; (2) 组成系统的物理元素清单; (3) 成本/效益分析; (4) 实现这个系统的进度计划; 推荐最佳方案: 分析员应该综合分析对比各种合理方案的利弊,推荐一个最佳的方案,并且为推荐的方案制定详细的实现计划; 用户和有关的技术专家应该认真审查分析员所推荐的最佳系统; 使用部门负责人进一步审批; 进入总体设计过程的下一个重要阶段——结构设计。 功能分解: 对程序(特别是复杂的大型程序)的设计,通常分为两个阶段完成: 结构设计:确定程序由哪些模块组成,以及这些模块之间的关系;是总体设计阶段的任务; 过程设计:确定每个模块的处理过程;是详细设计阶段的任务。 为确定软件结构,首先需要从实现角度把复杂的功能进一步分解。根据是数据流图。 功能分解导致数据流图的进一步细化,同时还应该用IPO图或其他适当的工具简要描述细化后每个处理的算法。 设计软件结构: 通常程序中的一个模块完成一个适当的子功能。应该把模块组织成良好的层次系统。 软件结构(即由模块组成的层次系统)可以用层次图或结构图来描绘。 如果数据流图已经细化到适当的层次,则可以直接从数据流图映射出软件结构。 设计数据库: 在需求分析阶段所确定的系统数据需求的基础上,设计数据库。 数据结构的设计从某种意义上讲是设计活动中最重要的一个。 制定测试计划: 在软件开发的早期阶段考虑测试问题,能促使软件设计人员在设计时注意提高软件的可测试性。 书写文档: (1)系统说明:主要内容包括用系统流程图描绘的系统构成方案,组成系统的物理元素清单,成本/效益分析;对最佳方案的概括描述,精化的数据流图,用层次图或结构图描绘的软件结构,用IPO图或其他工具(例如PDL语言)简要描述的各个模块的算法,模块间的接口关系,以及需求、功能和模块三者之间的交叉参照关系等等。 (2)用户手册:根据总体设计阶段的结果,修改更正在需求分析阶段产生的初步的用户手册。 (3)测试计划:包括测试策略,测试方案,预期的测试结果,测试进度计划等等。 (4)详细的实现计划 (5)数据库设计结果 审查和复审: 模块:可单独命名和可编址的部分。(另:由边界元素限定的相邻程序元素的序列,而且有一个总体标识符代表它)如: procedure, function, subroutine, block,section 模块化:程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。 模块化的根据: 设函数C(X)定义问题X的复杂程度, 且函数E(X)确定解决问题X需要的工作量(时间), 对于两个问题P1和P2,如果:C(P1)C(P2), 显然:E(P1)E(P2); 根据人类解决一般问题的经验,另一个
您可能关注的文档
- 《国家中长期教育改革和发展规划纲要》中期评估 学前教育专题评估报告.docx
- “熟人社会”向“陌生人社会”转型.docx
- “互联网+”构筑智慧长沙.ppt
- 《局域网技术与组网工程》第五次实验.ppt
- 《通信原理》试题库11信息论基础.doc
- 1+X 分享论坛-分享论坛串词.docx
- 1+X 分享论坛-分享空间雷声.pptx
- 1+X 分享论坛-主持串词.docx
- 1+X 分享论坛策划案.pdf
- 北大光华“沃土计划”进行时——羚锐集团的精准扶贫工作.doc
- 车海燕-软件工程-Lecture-SE-2013-Chap08.ppt
- 车海燕-软件工程-Lecture-SE-2013-Chap09.ppt
- 车海燕-软件工程-Lecture-SE-2013-Chap10-02.ppt
- 车海燕-软件工程-Lecture-SE-2013-Chap10-03.ppt
- 车海燕-软件工程-Lecture-SE-2013-Chap10-01.ppt
- 车向泉-微机原理及接口技术-chap03-01.pptx
- 车向泉-微机原理及接口技术-chap03-02.pptx
- 车向泉-微机原理及接口技术-chap02.pptx
- 车向泉-微机原理及接口技术-chap03-03.pptx
- 车向泉-微机原理及接口技术-chap03-addon-汇编语言的编译.pptx
最近下载
- 空分车间安全用电管理制度.docx VIP
- 2025政府采购评审专家入库题库与答案.docx VIP
- 2025-2026学年小学信息技术(信息科技)三年级上册(2024)黔科版(2024)教学设计合集.docx
- 结构动力学(哈尔滨工业大学)中国大学MOOC慕课章节测验答案.pdf VIP
- 危险化学品企业安全生产检查重点事项指导目录.pdf VIP
- 月度绩效考核评分表(通用类).docx VIP
- CNAS-CL02-2023 医学实验室质量和能力认可准则.docx VIP
- 法医临床司法鉴定考试题.docx VIP
- 地面、墙面、吊顶施工方案汇总.doc VIP
- 新解读《GB_T 23169-2019发制品 教习头》最新解读.pptx VIP
文档评论(0)