欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年软件工程第五讲教案 .pdf

    • 资源ID:38624768       资源大小:510.34KB        全文页数:17页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年软件工程第五讲教案 .pdf

    精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 17 页优质资料欢迎下载第五章软件详细设计详细设计又称过程设计, 在总体设计阶段, 已经确定了软件系统的总体结构,给出系统中各个组成模块的功能和模块间的联系。这一步的工作,就是要在上述结果的基础上,考虑“怎样实现”这个软件系统,直到对系统中的每个模块给出足够详细的过程性描述。需要指出,这些描述应该用详细设计的表达工具来表示,但它们还不是程序,一般不能够在计算机上运行。详细设计是编码的先导。这个阶段所产生的设计文档的质量,将直接影响下一阶段程序的质量。为了提高文档的质量和可读性,本章除要说明详细设计的目的、任务与表达工具外,还将扼要介绍结构程序设计的基本原理,以及如何用这些原理来指导模块内部的逻辑设计,提高模块控制结构的清晰度。5.1 详细设计的任务与原则详细设计的目的是为软件结构图( SC图或 HC图)中的每一个模块确定使用的算法和块内数据结构,并用某种选定的表达工具给出清晰的描述。表达工具可以由开发单位或设计人员选择,但表达工具必须具有描述过程细节的能力,进而可在编码阶段能够直接将它翻译为用程序设计语言书写的源程序。详细设计阶段的主要任务如下。1为每个模块确定采用的算法,选择某种适当的工具表达算法的过程,写出模块的详细过程性描述;2确定每一模块使用的数据结构;3确定模块接口的细节,包括对系统外部的接口和用户界面,对系统内部其它模块的接口,以及模块输入数据、输出数据及局部数据的全部细节。在详细设计结束时,应该把上述结果写入详细设计说明书,并且通过复审形成正式文档。交付给下一阶段(编码阶段)的工作依据。4要为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定的测试,模块的测试用例是软件测试计划的重要组成部分,通常应包括输入数据,期望输出等内容,其要求和设计方法将在第八章详细介绍,这里需要说明的一点是,由于负责详细设计的软件人员对模块的功能、逻辑和接口最清楚,所以可由他们在完成详细设计后接着提出对各个模块的测试要求。5.1.2 详细设计的原则1模块的逻辑描述要清晰易读、正确可靠。2采用结构化设计方法,改善控制结构,降低程序的复杂程度,从而提高程序的可读性、可测试性、可维护性。其基本内容归纳为如下几点。程序语言中应尽量少用 GOTO 语句,以确保程序结构的独立性。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 17 页优质资料欢迎下载使用单入口单出口的控制结构,确保程序的静态结构与动态执行情况相一致。保证程序易理解。程序的控制结构一般采用顺序、选择、循环三种结构来构成,确保结构简单。用自顶向下逐步求精方法完成程序设计。结构化程序设计的缺点是存储容量和运行时间增加 10 一 20,但可读性和可维护性好。3. 选择恰当描述工具来描述各模块算法。5.2 详细设计的方法采用自然语言来表达算法过程的优点是:能使不懂软件的人较易理解这些规格说明,但是,自然语言在语法和语义上有时具有多义性,且与上下文才相关,因此,必须采用更严密的描述工具来表达过程细节。主要的详细设计工具有 图形工具、 表格工具语言工具、简述如下。?图形工具利用图形工具可以把过程的细节用图形描述出来。?表格工具可以用一张表来描述过程的细节,在这张表中列出了各种可能的操作和相应的条件。?语言工具用某种高级语言(称之为伪码)来描述过程的细节。5.2.1 程序流程图程序流程图又称之为程序框图, 它是软件开发者最熟悉的一种算法表达工具。它独立于任何一种程序设计语言, 能比较直观和清晰地描述过程的控制流程,易于学习掌握。因此,程序流程图是软件开发者最普遍采用的一种工具。流程图也存在一些严重的不足,主要表现在:利用流程图使用的符号不够规范,使用的灵活性极大,程序员可以不受任何约束,随意转移控制。这些问题常常很大的影响了程序质量。为了消除这些不足,应严格的定义流程图所使用的符号,不允许随心所欲地画出各种不规范的流程图。为使用流程图描述结构化程序,必须限制在流程图中只能使用下述的五种基本控制结构。?顺序型顺序型由几个连续的处理步骤依次排列构成,如图 5-1 所示。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 17 页优质资料欢迎下载图 5-1 顺序型图 5-2 选择型图 5-3 while型循环?选择型选择型是指由某个逻辑判断式的取值决定选择两个处理中的一个,如图 5-2所示。? while型循环while 型循环是先判定型循环,在循环控制条件成立时,重复执行特定的处理,如图 5-3 所示。? until型循环until型循环是后判定型循环,重复执行某些特定的处理,直到控制条件成立为止,如图 5-4 所示。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 17 页优质资料欢迎下载图 5-4 until型循环?多情况型选择图 5-5 多情况型选择多情况型选择列举多种处理情况,根据控制变量的取值,选择执行其一,如图 5-5 所示。图 5-6 结构化程序流程图精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 17 页优质资料欢迎下载任何复杂的程序流程图都应由上述五种基本控制结构组合而成。图5-6 所示的是一个结构化程序的流程图。为了能够准确的使用流程图,要对流程图所使用的符号作出确切的规定。除去按规定使用定义了的符号之外, 流程图中不允许出现其他任何符号。 图 5-7给出国际标准化组织提出,并已为我国国家技术监督局批准的一些程序流程图标准符号,其中多数所规定的使用方法与普通的使用习惯用法相一致。图 5-7 标准程序流程图的规定符号5.2.2 N-S 图Nassi 和 Shneiderman 提出了一种符合结构化程序设计原则的图形描述工具,称之为盒图,又称之为N-S图。在 N-S图中,为了表示五种基本控制结构,规定了五种图形构件。?顺序型如图 5-8 所示,在顺序型中,先执行A,后执行 B。图 5-8 顺序型结构?选择型如图 5-9 所示,在选择型结构中,如果条件P成立,则可执行 T下面的 A的内容,当条件 P不成立时,则执行F下的内容。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 17 页优质资料欢迎下载图 5-9 选择型结构? WHILE重复型如图 5-10 所示,在 WHILE 重复型循环结构中,先判断P的值,再执行 S。其中 P是循环条件, S是循环体图 5-10 WHILE重复型循环结构? UNTIL 重复型如图 5-11 所示,在 UNTIL重复型循环结构中,先执行S,后判断 P的值。图 5-11 UNTIL 重复型循环结构?多分支选择型如图 5-12 所示,给出了多出口的判断图形表示,P为控制条件,根据 P的取值,相应地执行其值下面的各框内容。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 17 页优质资料欢迎下载图 5-12 多分支选择型例: 将图 5-6 所示的程序流程图转化为N-S图的结果如图 5-13 所示。图 5-13 N-S 图举例N-S 图的特点?图形清晰、准确;?控制转移不能任意规定,必须遵守结构化程序设计原则;?很容易确定局部数据和全局数据的作用域;?容易表现嵌套关系和模块的层次结构。5.2.3 PAD 图PAD是 Problem analysis diagram的英文缩写,它是日本日立公司提出的。它是用结构化程序设计思想表现程序逻辑结构的图形工具。PAD也设置了五种基本控制结构的图示,并允许递归使用。1. 顺序型精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 17 页优质资料欢迎下载如图 5-14 所示,按顺序先执行A,再执行 B。图 5-14 顺序型结构2. 选择型如图 5-15 所示,给出了判断条件为P的选择型结构。 当 P为真值时执行上面的 A框, P取假值时执行下面的 B 框中的内容。如果这种选择型结构只有A 框,没有 B框,表示该选择结构中只有THEN 后面有可执行语句A,没有 ELSE部分。图 5-15 选择型结构3.WHILE重复型和 UNTIL重复型如图 5-16 所示, P是循环判断条件, S是循环体。循环判断条件框的右端为双纵线,表示该矩形域是循环条件,以区别于一般的矩形功能域。图 5-16 WHILE重复型和 UNTIL重复型结构4. 多分支选择型如图 5-17 所示,多分支选择型是CASE 型结构。当判定条件P等于 1 时执行A1框的内容, P等于 2 时执行 A2框的内容, P等于 N时执行 An框的内容。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 9 页,共 17 页优质资料欢迎下载图 5-17 多分支选择型结构5.PAD图应用举例图 5-18 给出了图 5-6 所示的程序流程图的PAD图。图 5-18 PAD 图举例6.PAD图特点? PAD图的结构化程度高;? PAD图中的是程序的主干线,即程序的第一层结构。其后,每增加一个层次,则向右扩展一条纵线。程序中的层数就是PAD 图中的纵线数。因此,PAD图的可读性强。?利用 PAD图设计出的程序必定是结构化的程序。?利用软件工具可以将 PAD图转换成高级语言程序,进而提高了软件的可靠性和生产率。? PAD图支持自顶向下的逐步求精的方法。7PAD图的扩充结构为了反映增量型循环结构,在 PAD图中增加了对应于FOR i := n1 to n2 step n3 do 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 17 页优质资料欢迎下载的循环控制结构, 如图 5-19(A) 所示。其中,n1 是循环初值, n2 是循环终值,n3 是循环增量。图 5-19 PAD 的扩充控制结构另外, PAD所描述程序的层次关系表现在纵线上。每条纵线表示一个层次。把 PAD 图从左到右展开,随着程序层次的增加,PAD逐渐向右展开,有可能会超过一页纸,这时,对PAD 增加了一种如图5-20(B) 所示的扩充形式。当一个模块 A在一页纸上画不下时,可在图中该模块相应位置矩形框中简记一个“NAME A ”,再在另一页纸上详细画出A的内容,用 def 及双下划线来定义作 A的 PAD 。这种方式可使在一张纸上画不下的图,分在几张纸上画出,也可以用它定义子程序。5.2.4 PDL PDL (Procedure Design Language)为过程设计语言的英文缩写,于1975 年由 Caine 与 Gordon首先提出。PDL是所有非正文形式的过程设计工具的统称,到目前为止已出现多种PDL语言。? PDL 语言的特点?关键字采用固定语法并支持结构化构件、数据说明机制和模块化;?处理部分采用自然语言描述;?可以说明简单和复杂的数据结构;?子程序的定义与调用规则不受具体接口方式的影响。? PDL 描述选择结构利用 PDL 描述的 IF 结构如下:IF 一条或数条语句精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 11 页,共 17 页优质资料欢迎下载ELSEIF 一条或数条语句ELSEIF 一条或数条语句ELSE 一条或数条语句ENDIF ? PDL 描述循环结构对于三种循环结构,利用 PDL 描述如下。 WHILE循环结构DO WHILE 一条或数条语句ENDWHILE UNTIL 循环结构REPEAT UNTIL 一条或数条语句ENDREP FOR 循环结构FOR 循环变量 =循环变量取值范围,表达式或序列ENDFOR ?子程序PROCEDURE INTERFACE 一条或数条语句END 属性表指明了子程序的引用特性和利用的程序语言的特性。?输入 / 输出READ/WRITE TO 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 17 页优质资料欢迎下载综上可见, PDL具有很强的描述功能,是一种十分灵活和有用的详细设计表达工具。5.2.5 HIPO 图HIPO图是由一组 IPO图和一张 HC图组成。用 HC图描述软件结构,用IPO图描述程序过程,它是美国IBM公司在软件设计中使用的主要表达工具。HC图是层次图( Hierarchy chart)的英文缩写,用于表示软件的分层结构。HC图中的每一个模块,均可用一张IPO图来描述。 IPO 图由输入、处理和输出三个框组成,需要时还可以增加一个数据文件框,如图5-20 所示。图中处理框内的加工逻辑是用N-S图表达的。当然也可由其他详细设计的表达工具来表示。这种图形的优点是能够直观地显示输入、处理、输出三者之间的联系。后来将这种传统的IPO图改成如图 5-22 所示的式样, 使它在设计阶段和分析阶段都可使用。显然,图中有一部分内容在分析阶段还无法填写,填在处理框中的加工策略,到了设计阶段也要进一步细化。但无论如何,它总是为设计阶段所需的IPO图提供了基础。在任何良好的开发方法中,希望前一阶段产生的文档能够方便地转化成后继阶段的文档,这正是这种改进了的IPO图的一个优点。图 5-20 传统的 IPO图精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13 页,共 17 页优质资料欢迎下载图 5-21 改进的 IPO图HIPO图已成为一套自成体系的设计表达工具。不仅如此,在需求分析阶段还可以用 IPO图来描述加工策略。所以虽然用 HIPO图制成的设计文档篇幅较大。5.2.6 详细设计工具的选择在详细设计中,对一个工程设计选择的原则是:过程描述是否易于理解、复审和维护,进而过程描述能够自然地转换成代码,并保证详细设计与代码完全一致。为了达到这一原则,要求设计工具具有下述属性。?模块化支持模块化软件的开发,并提供描述接口的机制。例如,能够直接表示子程序和块结构。?简洁设计描述易学、易用和易读。?便于编辑支持后续设计和维护以及在维护阶段对设计进行的修改。?机器可读性设计描述能够直接输入,并且很容易被计算机辅助设计工具识别。?可维护性详细设计应能够支持各种软件配置项的维护。?自动生成报告精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 17 页优质资料欢迎下载设计者通过分析详细设计的结果来改进设计。通过自动处理器产生有关分析报告,进而增强设计者在这方面的能力。?强制结构化详细设计工具能够强制设计者采用结构化构件,有助于采用优秀的设计。?数据表示详细设计具备表示局部数据和全局数据的能力。?逻辑验证软件测试最高目标是能够自动检验设计逻辑的正确性,所以设计描述应易于进行逻辑验证,进而增强可测试性。( 10)编码能力可编码能力是一种设计描述,研究代码自动转换技术可以提高软件效率和减少出错率。5.3 详细设计规格说明与复审建立设计文档的目的是为了把设计师的思想告诉其他有关人员。程序是由计算机执行的,但可读性提高便于维护。在详细设计阶段的文档是详细设计说明书。它是程序工作过程的描述。详细设计说明书的内容主要包括:表示软件结构的图表;对逐个模块的描述,包括算法和逻辑流程,输入 / 输出项,与外部接口等。一个典型的详细设计说明书的框架如图 5-22 所示。详细设计说明书?引言? 1 编写目的说明编写详细说明书的目的,并指明读者的对象。? 2 项目背景包括项目的来源和主管部门等。? 3 定义列出文档中所用的专门术语的定义和缩写词的原意。? 4 参考资料列出有关资料的作者、标题、编号、发表日期、出版单位或资料来源。可包括:项目计划任务书、合同或批文、项目开发计划、需求规格说明书、总体精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共 17 页优质资料欢迎下载设计说明书、测试计划、用户操作手册、文档中所引用的其它资料、软件开发标准或规范。2. 总体设计21 需求概述22 软件结构给出软件系统的结构图。3. 程序描述对每个模块给出以下说明:3.1 功能3.2 性能3.3 输入项目3.4 输出项目3.5 算法模块所选用的算法3.6 程序逻辑详细描述模块实现的算法,可以采用流程图、 PDL 语言、 N-S图、PAD图等描述算法的图表。3.7 接口3.8 存储分配3.9 限制条件3.10 测试要点给出测试模块的主要测试要求。5.3.2 设计复审设计复审是非常重要的工作,设计复审主要是指对设计文档的复审。?复审的指导原则详细设计复审一般不邀请用户和其他领域的代表。复审是为了提早揭露错误,参加复审的设计人员应该欢迎别人提出批评和建议,但复审的对象是设计文档,不是设计者本身,其他参加者也应为复审创造和谐的气氛。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 16 页,共 17 页优质资料欢迎下载复审中提出的问题应详细记录,但不一定当场解决。复审结束前作出本次复审能否通过的结论。2复审的主要内容详细设计复审的重点应该放在各个模块的具体设计上。例如模块的设计能否满足其功能与性能要求、选择的算法与数据结构是否合理、符不符合编码语言的特点、设计描述是否简单、清晰等等。3复审的方式复审分正式与非正式两种方式,非正式复审的特点是参加人数少,且均为软件人员,带有同行讨论的性质。因而方便灵活,十分适合于详细设计复审。常采用的非正式复审的过程是:由一名设计人员逐行宣读设计资料,由到会的同行跟随他指出的次序一行行的往下审查。发现有问题或错误就做好记录,然后根据多数参加者的意见, 决定通过该设计资料或退回原设计人进行纠正。正式复审除软件开发人员外,还邀请用户代表和领域专家参加,通常采用答辩方式,与会者要提前审阅文档资料,设计人员对设计方案详细说明之后,回答与会者的问题并记录各种重要的评审意见。小结详细设计的关键任务是确定怎样具体地实现所要求的目标系统,也就是要设计出程序的蓝图。除了应该保证程序的可靠性之外,使将来编写出的程序的可读性好,容易理解,容易测试和容易修改、维护是详细设计的最重要的目标。程序流程图、盒图、 PAD图、HIPO图和 PDL语言等等都是完成详细设计的工具,选择合适的工具并且正确的使用它们是十分重要的。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 17 页,共 17 页

    注意事项

    本文(2022年软件工程第五讲教案 .pdf)为本站会员(H****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

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

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

    收起
    展开