- 1、本文档共47页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[工学]D第四章 详细设计
概述 结构化构造 图形设计工具 伪码与程序设计语言 各种详细设计工具的比较 详细设计文件与复审 在理想的情况下,详细设计步骤需要的过程描述应当用自然语言来表达。 但是,详细设计必须是无歧义地描述过程的细节,而自然语言却不具有单一性。必须使用更有约束性的方式来表示过程细节。 在概要设计期间,每个模块被定义为软件总体结构的组成部分,用自然语言编写结构图和接口说明、模块的处理说明和性能说明。 为了把这些简明的、无歧义的一般处理步骤的描述转换为准确的、结构过程的描述,就需要使用设计描述工具。 过程规格说明的工具称之为详细设计工具,可分为: 图形工具:把过程的细节表示成一个“图”的组成部分,在这个图上,逻辑构造用具体的图形来表示。 列表工具:用一个表来表示过程的细节,表列出了各种操作及相应的条件。 语言工具:用类语言来表示过程的细节,类语言很接近编程语言。 不管属于哪一类,一种设计工具应表现出控制的流程、处理功能、数据的组织及实现的细节。 提出这些结构化构造的目的是限制软件的过程设计,只允许采用几种预定的操作。 采用这些结构化构造将减少程序的复杂性,从而提高软件的可读性、可测试性和可维护性。 使用有限的几种逻辑构造还有助于人们用“成块识别”的方式去理解进程。 任何一个程序,不管它的应用领域或技术复杂性如何,都可以仅仅用这3种结构化构造来设计和实现。 详细设计中的图形工具有: 流程图 方块图(N-S图) HIPO图 PAD图等 这些图形工具提供了极好的图形样式,通过它们,可以方便地描述过程的细节。 流程图独立于各种程序设计语言,比较直观、清晰,易于学习掌握。然而,它也是经常被误用的一种方法。 为使流程图能描述结构化程序,限制流程图只能由几种基本控制结构组成,或者说任一程序流程图都应能由几种基本控制结构嵌套而成。 ISO5807《信息处理——数据流程图、程序流程图、系统流程图、程序网络图和系统资源图的文件编制符号及约定》中对程序流程图的符号做出了规定。 通常,当需要从一组嵌套的循环构造或者嵌套的条件构造中离去时,只简单地采用结构化构造有可能使效率降低,甚至沿着离去路径使所有逻辑测试复杂化,从而使软件的控制流程变得模糊不清,增加了出错的可能性,并且对可读性和可维护性也有不良影响。这时,可以有两种选择: 重新设计程序流程,使得在控制流程的嵌套部位不需要出现离去分支。 有控制地采用非结构化的构造;也就是说,设计成有限制地从嵌套流程中往外分支。 方块图是一种强制使用结构化构造的图示工具,具有下列特点: 明确规定功能域 (即某一具体构造的功能范围) ,并且很直观地从图形表示中看出来。 不可能随意分支或转移。 可以很容易地确定局部数据和 (或) 全程数据的作用域。 容易表示出递归结构。 HIPO(层次加输入-处理-输出) 是根据IBM公司研制的软件设计与文件编制技术发展而来的一种图示工具。 在概要设计、详细设计、设计评审、测试和维护的不同阶段,都可以使用HIPO图对设计进行描述。 HIPO图的最重要的特征是它能够表示输入/输出数据 (外部数据和内部数据流程) 与软件的过程之间的关系。 完整的一组HIPO图由下列各部分组成: 层次图 (H图) :以层次方框形式表达程序主功能模块与次功能模块的关系。 高层IPO图:针对H图中的主功能模块和次功能模块,描述其输入,处理功及输出等。 低层IPO图:给出H图中最低层次的具体设计。 在画H图时要注意几个问题: 根据经验,一般每层画3-10个功能模块为宜。 对于画到第几层为止则无统一标准,视具体情况而定。 画高层IPO时,从H层第一层开始画,按自上而下,从左到右的顺序画出H图中每个方框 (除最底层外) 的IPO图。在IPO图上给出哪些是输入,处理的功能是什么,输出什么。 为了避免规模和维护上的复杂性问题,大多数项目的HIPO图只深入到某一层。 PAD (问题分析图) 是一种用于软件详细设计的表达形式: 综合流程图、Warnier图(类似判定树)、方块图和伪码等技术的一些特点; 以二维树的形式描述程序的逻辑; 主要优点是程序结构清晰,能够直接导出程序代码,并对其一致性进行检查; 可应用于BASIC、FORTRAN、COBOL、PASCAL等高级语言; 支持软件需求分析和概要设计阶段。 伪码是控制结构和某些编程语言元素的简写符号,可以任意插入注释,实质上是“文字流程图”。 熟悉某种程序设计语言的设计人员所用的伪码可能就是该语言的简化版本 。 实际使用时,设计人员可以随意增加伪码的详细程度,特别是针对可能产生二义性的地方。 伪码的缺点是不标准,而且只有控制结构,对数据描述能力很差。 程序设计语言 (PDL,又称详细设计语言DDL) 弥补了伪码的缺点,它是一种“混杂式语言”。 它采用某种语言 (例如英语) 的词汇但却采用另
文档评论(0)