详细设计课件_第1页
详细设计课件_第2页
详细设计课件_第3页
详细设计课件_第4页
详细设计课件_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第五章详细设计第1页,共38页。详细设计(过程设计、模块设计)目标:确定如何实现所要求的系统对目标系统的精确描述逻辑上正确实现每个模块的功能处理过程简单易懂第2页,共38页。5.1 结构程序设计程序的三种基本控制结构第3页,共38页。5.1 结构程序设计结构程序设计如果一个程序的代码块仅仅通过顺序、选择和循环这三种控制结构进行连接,并且每个代码块只有一个入口和一个出口,则称这个程序是结构化的结构程序设计本质上并不是无GO TO语句的编程方法,而是一种使程序代码容易阅读、容易理解的编程方法。根据实际情况灵活掌握goto的使用 结构程序设计是尽可能少用GO TO语句的程序设计方法。最好仅在检测出错

2、误时才使用GO TO语句,而且应该总是使用前向GO TO语句。如果只允许使用顺序、IF-THEN-ELSE型分支和DO-WHILE型循环这三种基本控制结构,则称为经典的结构程序设计;第4页,共38页。5.1 结构程序设计如果除了上述三种基本控制结构之外,还允许使用DO-CASE型多分支结构和DO-UNTIL型循环结构,则称为扩展的结构程序设计;如果再加上允许使用LEAVE(或BREAK)结构,则称为修正的结构程序设计。第5页,共38页。5.2 详细设计过程为每个模块确定采用的算法,写出模块的详细描述确定模块使用的数据结构确定模块接口的详细描述对系统外部的接口和用户界面对系统内部其他模块的接口关

3、于模块输入数据、输出数据和局部数据的全部细节第6页,共38页。5.2 详细设计过程设计原则清晰第一、效率第二结构化的控制结构控制结构应一个入口、一个出口允许使用 DO-UNTIL和DO-CASE允许循环跳出逐步细化的实现方法在一组数中找出其中的最大数1,输入一组数2,找出其中最大的数3,输出最大数2.1,任取一数,假设它就是最大数2.2,将该数与其余各数逐一比较2.3,若发现有任意数大于该假设最大数,则取而代之1,输入一个数组2.1,令最大数=数组中第一个数2.2,从第二个数到最后一个数依次做2.3,如果最大数,则最大数=新数3,输出最大数第7页,共38页。5.3 过程设计工具程序流程图程序流

4、程图又称为程序框图,历史最悠久使用最广泛的描述过程设计的方法然而它也是用得最混乱的一种方法任意跳转第8页,共38页。5.3 过程设计工具程序流程图中使用的符号(a) 选择(分支);(b) 注释;(c) 预先定义的处理;(d) 多分支;(e) 开始或停止;(f) 准备;(g)循环上界限;(h) 循环下界限;(i) 虚线;(j) 省略符;(k) 并行方式;(l) 处理;(m) 输入/输出;(n) 连接;(o) 换页连接;(p) 控制流第9页,共38页。5.3 过程设计工具盒图第10页,共38页。5.3 过程设计工具PAD图的基本符号顺序(先执行P1后执行P2);(b) 选择(IF C THEN P

5、1 ELSE P2);(c) CASE型多分支;(d) WHILE型循环(WHILE C DO P)(e) UNTIL型循环(REPEAT P UNTIL C);(f) 语句标号;(g) 定义第11页,共38页。5.3 过程设计工具使用PAD图提供的定义功能来逐步求精的例子(a) 初始的PAD图;(b) 使用def符号细化处理框P2第12页,共38页。5.3 过程设计工具第13页,共38页。5.3 过程设计工具第14页,共38页。Jackson方法(1)分析并确定输入数据和输出数据的逻辑结构,并用Jackson结构图来表示这些数据结构。 (2)找出输入数据结构和输出数据结构中有对应关系的数据单

6、元。 (3)按以下的规则由输入、输出的数据结构导出程序结构。 1)为每一对在输入数据结构和输出数据结构中有对应关系的单元画一个处理框。 2)为输入和输出数据结构中剩余的数据单元画一个处理框。 3)所有处理框在程序结构图上的位置,应与由它处理的数据单元在数据结构Jackson图上的位置一致。 4)必要时,可以对映射导出的程序结构图进行进一步的细化。 (4)列出基本操作与条件,并把它们分配到程序结构图的适当位置。 (5)用伪码写出程序。 第15页,共38页。操作对象是一种文件,该文件由三部分组成:文件头、文件体和文件尾。文件体由特定分隔符分成许多记录组,记录根据其特征码分类记录和类记录。文件统计系

7、统读取以上结构的文件,显示文件头,计算记录组数以及类记录和类记录记录个数,并打印输出。文件文件体记录组记录类记录类记录文件头文件尾第16页,共38页。处理文件处理文件体处理记录组处理记录处理类记录处理类记录处理文件头处理文件尾(2) (3)(3) (4) (5) (6) (7) (8) (9)(2) (10)(2)(11)(12)打开文件(1)关闭文件(8)读文件(2)显示总数(7)组计数器清零(4)A计数器清零(5)组计数器累加(10)终止(9)B计数器累加(12)A计数器累加(11)B计数器清零(6)显示文件头(3)第17页,共38页。Seq open file; read file; s

8、eq display file header; read file; end; seg zeroise group count(GC); zeroise group count(AC); zeroise group count(BC); iter while not EOF increment GC; iter while not EOF select record A increment AC; or record B increment BC; read file; end; end; end; close file; display total; end;第18页,共38页。5.4 程序

9、复杂程度的定量度量McCabe方法根据程序控制流的复杂程度度量程序的复杂程度,程序的环路复杂度符号为控制流图的一个结点,表示一个或多个无分支的PDL语句或源程序语句。箭头为边,表示控制流的方向。每个包含了条件的节点称为判定节点第19页,共38页。5.4 程序复杂程度的定量度量在选择或多分支结构中,分支的汇聚处应有一个汇聚结点。边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域第20页,共38页。5.4 程序复杂程度的定量度量第21页,共38页。5.4 程序复杂程度的定量度量如果判断中的条件表达式是由一个或多个逻辑运算符 (OR, AND, NAND, NOR) 连接的复合

10、条件表达式,则需要改为一系列只有单个条件的嵌套的判断。第22页,共38页。5.4 程序复杂程度的定量度量第23页,共38页。5.4 程序复杂程度的定量度量环路复杂度V(G)是对程序逻辑复杂性进行度量的尺度。可以通过流图得到:流图中的区域数等于V(G)V(G)=E-N+2,E为边数,N为结点数。V(G)=P+1,P为流图中分支结点数。第24页,共38页。令N=N1+N2N1 程序中运算符出现的总数N2 操作数出现的总数N 程序长度第25页,共38页。START LOOP:DO WHILE Z0 1,是否是结构化程序 A=B+1 2,如何改成结构化程序 IF A10 3,环形复杂度? THEN X

11、=A ELSE Y=Z ENS IF IF Y0 THEN PRINT G ELSE PRINT KEND IFSTOP第26页,共38页。5.5 人机界面设计人机界面设计是接口设计的一个组成部分。对于交互式系统来说,人机界面设计和数据设计、体系结构设计、过程设计一样重要。近年来,人机界面在系统中所占的比例越来越大,在个别系统中人机界面的设计工作量甚至占设计总量的一半以上。人机界面的设计质量,直接影响用户对软件产品的评价,从而影响软件产品的竞争力和寿命,因此,必须对人机界面设计给以足够重视第27页,共38页。5.5 人机界面设计在设计用户界面的过程中的四个主要问题系统响应时间系统响应时间是许多

12、交互式系统用户经常抱怨的问题。一般说来,系统响应时间指从用户完成某个控制动作(例如,按回车键或点击鼠标),到软件给出预期的响应(输出或做动作)之间的这段时间。系统响应时间有两个重要属性,分别是长度和易变性。用户帮助设施几乎交互式系统的每个用户都需要帮助,当遇到复杂问题时甚至需要查看用户手册以寻找答案。大多数现代软件都提供联机帮助设施,这使得用户可以不离开用户界面就解决自己的问题常见的帮助设施有集成的和附加的两类。第28页,共38页。5.5 人机界面设计出错信息处理出错信息和警告信息,是出现问题时交互式系统给出的“坏消息”。出错信息设计得不好,将向用户提供无用的或误导的信息,反而增加了用户的挫折

13、感。命令交互命令行曾经是用户和系统软件交互的最常用方式,而且也曾经广泛地用于各种应用软件中。现在,面向窗口的、点击和拾取方式的界面已经减少了用户对命令行的依赖,但是,许多高级用户仍然偏爱面向命令的交互方式。在多数情况下,用户既可以从菜单中选择软件功能也可以通过键盘命令序列调用软件功能。第29页,共38页。5.5 人机界面设计用户界面设计是一个迭代的过程,也就是说,通常先创建设计模型,再用原型实现这个设计模型,并由用户试用和评估,然后根据用户的意见进行修改。用户界面设计主要依靠设计者的经验。总结众多设计者的经验而得出的设计指南,有助于设计者设计出友好、高效的人机界面。本节介绍三类人机界面设计指南

14、。第30页,共38页。5.5 人机界面设计一般交互指南:一般交互指南涉及信息显示、数据输入和整体系统控制,因此,这些指南是全局性的,忽略它们将承担较大风险。下面叙述一般交互指南。保持一致性。为人机界面中的菜单选择、命令输入、数据显示以及众多的其他功能,使用一致的格式。 提供有意义的反馈。向用户提供视觉的和听觉的反馈,以保证在用户和界面之间建立双向通信。在执行有较大破坏性的动作之前要求用户确认。如果用户要删除一个文件,或覆盖一些重要信息,或请求终止一个程序运行,应该给出“您是否确实要”的信息,以请求用户确认他的命令。允许取消绝大多数操作。UNDO或REVERSE功能使众多终端用户避免了大量时间浪

15、费。每个交互式应用系统都应该能方便地取消已完成的操作。第31页,共38页。5.5 人机界面设计减少在两次操作之间必须记忆的信息量。不应该期望用户能记住一大串数字或名字,以便在下一步操作中使用它们。应该尽量减少记忆量。提高对话、移动和思考的效率。应该尽量减少击键次数,设计屏幕布局时应该考虑尽量减少鼠标移动的距离,应该尽量避免出现用户问:“这是什么意思”的情况。允许犯错误。系统应该保护自己不受致命错误的破坏。按功能对动作分类,并据此设计屏幕布局。下拉菜单的一个主要优点就是能按动作类型组织命令。实际上,设计者应该尽力提高命令和动作组织的“内聚性”。提供对工作内容敏感的帮助设施用简单动词或动词短语作为

16、命令名。过长的命令名难于识别和记忆,也会占据过多的菜单空间第32页,共38页。5.5 人机界面设计信息显示指南:如果人机界面显示的信息是不完整的,含糊的或难于理解的,则应用软件显然不能满足用户的需求。可以用多种不同方式“显示”信息:用文字、图片和声音;按位置、移动和大小;使用颜色、分辨率和省略。下面是关于信息显示的设计指南。只显示与当前工作内容有关的信息。用户在获得有关系统的特定功能的信息时,不必看到与之无关的数据、菜单和图形。不要用数据淹没用户,应该用便于用户迅速地吸取信息的方式来表示数据。例如,可以用图形或图表来取代巨大的表格。使用一致的标记、标准的缩写和可预知的颜色。显示的含义应该非常明

17、确,用户不必参照其他信息源就能理解。第33页,共38页。5.5 人机界面设计允许用户保持可视化的语境。如果对图形显示进行缩放,原始的图像应该一直显示着(以缩小的形式放在显示屏的一角),以使用户知道当前观察的图像部分在原图中所处的相对位置。产生有意义的出错信息使用大小写、缩进和文本分组以帮助理解。人机界面显示的信息大部分是文字,文字的布局和形式对用户从中吸取信息的难易程度有很大影响。使用窗口分隔不同类型的信息。利用窗口用户能够方便地“保存”多种不同类型的信息第34页,共38页。5.5 人机界面设计使用“模拟”显示方式表示信息,以使信息更容易被用户吸取。例如,显示炼油厂储油罐的压力时,如果使用简单

18、的数字表示压力,则不易引起用户注意。但是,如果用类似温度计的形式来表示压力,用垂直移动和颜色变化来指示危险的压力状况,就能引起用户的警觉,因为这样做为用户提供了绝对和相对两方面的信息高效率地使用显示屏。当使用多窗口时,应该有足够的空间使得每个窗口至少都能显示出一部分。此外,屏幕大小应该选得和应用系统的类型相配套(这实际上是一个系统工程问题)。第35页,共38页。数据输入指南用户的大部分时间用在选择命令、键入数据和向系统提供输入。在许多应用系统中,键盘仍然是主要的输入介质,但是,鼠标、数字化仪和语音识别系统正迅速地成为重要的输入手段。下面是关于数据输入的设计指南。尽量减少用户的输入动作。最重要的是减少击键次数,这可以用下列方法实现:用鼠标从预定义的一组输入中选一个;用“滑动标尺”在给定的值域中指定输入值;利用宏把一次击键转变成更复杂的输入数据集合。保持信息显示和数据输入之间的一致性。显示的视觉特征(例如,文字大小、颜色和位置)应该与输入域一致。第36页,共38页。允许用户自定义输入。专家级的用户可能希望定义自己专用的命令或略去某些类型的警告信息和动作确认,人机界面应该允许用户这样做。交互应该是灵活的,并

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论