1、软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 1第五章第五章详细设计详细设计软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 2详细设计(过程设计、模块设计)l 目标:确定如何实现所要求的系统l对目标系统的精确描述l逻辑上正确实现每个模块的功能l处理过程简单易懂软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 35.1 结构程序设计l 程序的三种基
2、本控制结构软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 45.1 结构程序设计l 结构程序设计l如果一个程序的代码块仅仅通过顺序、选择和循环这三种控制结构进行连接,并且每个代码块只有一个入口和一个出口,则称这个程序是结构化的l结构程序设计本质上并不是无GO TO语句的编程方法,而是一种使程序代码容易阅读、容易理解的编程方法。l根据实际情况灵活掌握goto的使用 l结构程序设计是尽可能少用GO TO语句的程序设计方法。最好仅在检测出错误时才使用GO TO语句,而且应该总是使用前向GO TO语句。l如果只允许使用
3、顺序、IF-THEN-ELSE型分支和DO-WHILE型循环这三种基本控制结构,则称为经典的结构程序设计;软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 55.1 结构程序设计l 如果除了上述三种基本控制结构之外,还允许使用DO-CASE型多分支结构和DO-UNTIL型循环结构,则称为扩展的结构程序设计;如果再加上允许使用LEAVE(或BREAK)结构,则称为修正的结构程序设计。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 6
4、5.2 详细设计过程l 为每个模块确定采用的算法,写出模块的详细描述l 确定模块使用的数据结构l 确定模块接口的详细描述l对系统外部的接口和用户界面l对系统内部其他模块的接口l关于模块输入数据、输出数据和局部数据的全部细节软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 75.2 详细设计过程l 设计原则l清晰第一、效率第二l结构化的控制结构l 控制结构应一个入口、一个出口l 允许使用 DO-UNTIL和DO-CASEl 允许循环跳出l逐步细化的实现方法l 在一组数中找出其中的最大数1,输入一组数2,找出其中最大
5、的数3,输出最大数2.1,任取一数,假设它就是最大数2.2,将该数与其余各数逐一比较2.3,若发现有任意数大于该假设最大数,则取而代之1,输入一个数组2.1,令最大数=数组中第一个数2.2,从第二个数到最后一个数依次做2.3,如果最大数,则最大数=新数3,输出最大数软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 85.3 过程设计工具l 程序流程图l程序流程图又称为程序框图,l历史最悠久使用最广泛的描述过程设计的方法l然而它也是用得最混乱的一种方法l任意跳转任意跳转软件工程(Software Engineeri
6、ng)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 95.3 过程设计工具程序流程图中使用的符号程序流程图中使用的符号(a)选择选择(分支分支);(b)注释;注释;(c)预先定义的处理;预先定义的处理;(d)多分支;多分支;(e)开始或停止;开始或停止;(f)准备;准备;(g)循环上界限;循环上界限;(h)循环下界限;循环下界限;(i)虚线;虚线;(j)省略符;省略符;(k)并行方式;并行方式;(l)处理;处理;(m)输入输入/输出;输出;(n)连接;连接;(o)换页连接;换页连接;(p)控制流控制流软件工程(Software Engineering)沈阳工业
7、大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 105.3 过程设计工具盒图软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 115.3 过程设计工具PADPAD图的基本符号图的基本符号(a)(a)顺序顺序(先执行先执行P1P1后执行后执行P2)P2);(b)(b)选择选择(IF C THEN(IF C THEN P1 ELSE P2)P1 ELSE P2);(c)CASE(c)CASE型多分支;型多分支;(d)WHILE(d)WHILE型循环型循环(WHILE C DO P)(WHILE
8、 C DO P)(e)UNTIL(e)UNTIL型循环型循环(REPEAT P(REPEAT P UNTIL C)UNTIL C);(f)(f)语句标号;语句标号;(g)(g)定义定义软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 125.3 过程设计工具使用使用PAD图提供的定义功能来逐步求精的例子图提供的定义功能来逐步求精的例子(a)初始的初始的PAD图;图;(b)使用使用def符号细化处理框符号细化处理框P2软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息
9、科学与工程学院 魏东 Slide 135.3 过程设计工具软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 145.3 过程设计工具软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 15Jackson方法l(1)分析并确定输入数据和输出数据的逻辑结构,并用Jackson结构图来表示这些数据结构。l(2)找出输入数据结构和输出数据结构中有对应关系的数据单元。l(3)按以下的规则由输入、输出的数据结构导出程序结构。l1)为每一对在输入数
10、据结构和输出数据结构中有对应关系的单元画一个处理框。l2)为输入和输出数据结构中剩余的数据单元画一个处理框。l3)所有处理框在程序结构图上的位置,应与由它处理的数据单元在数据结构Jackson图上的位置一致。l4)必要时,可以对映射导出的程序结构图进行进一步的细化。l(4)列出基本操作与条件,并把它们分配到程序结构图的适当位置。l(5)用伪码写出程序。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 16l操作对象是一种文件,该文件由三部分组成:文件头、文件体和文件尾。文件体由特定分隔符分成许多记录组,记录根据其
11、特征码分类记录和类记录。文件统计系统读取以上结构的文件,显示文件头,计算记录组数以及类记录和类记录记录个数,并打印输出。文件文件体记录组记录类记录类记录文件头文件尾软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 17处理文件处理文件体处理记录组处理记录处理类记录处理类记录处理文件头处理文件尾(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、12)A计数器累加(11)B计数器清零(6)显示文件头(3)软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 18Seq open file;read file;seq 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
13、 A increment AC;or record B increment BC;read file;end;end;end;close file;display total;end;软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 195.4 程序复杂程度的定量度量l McCabe方法l根据程序控制流的复杂程度度量程序的复杂程度,l程序的环路复杂度l符号为控制流图的一个结点,表示一个或多个无分支的PDLPDL语句或源程序语句。箭头为边,表示控制流的方向。每个包含了条件的节点称为判定节点软件工程(Software
14、 Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 205.4 程序复杂程度的定量度量l在选择或多分支结构中,分支的汇聚处应有一个汇聚结点。l边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 215.4 程序复杂程度的定量度量软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 225.4 程序复杂程度的定量度量
15、l 如果判断中的条件表达式是由一个或多个逻辑运算符(OR,AND,NAND,NOR)OR,AND,NAND,NOR)连接的复合条件表达式,则需要改为一系列只有单个条件的嵌套的判断。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 235.4 程序复杂程度的定量度量软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 245.4 程序复杂程度的定量度量l 环路复杂度V(G)是对程序逻辑复杂性进行度量的尺度。可以通过流图得到:l流图中的区域
16、数等于V(G)lV(G)=E-N+2,E为边数,N为结点数。lV(G)=P+1,P为流图中分支结点数。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 25l令lN=N1+N2lN1 程序中运算符出现的总数lN2 操作数出现的总数lN 程序长度222121loglognnnnH300/)(log212nnNE软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 26START LOOP:DO WHILE Z0 1,是否是结构化程序 A=
17、B+1 2,如何改成结构化程序 IF A10 3,环形复杂度?THEN X=A ELSE Y=Z ENS IF IF Y0 THEN PRINT G ELSE PRINT KEND IFSTOP软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 275.5 人机界面设计l 人机界面设计是接口设计的一个组成部分。对于交互式系统来说,人机界面设计和数据设计、体系结构设计、过程设计一样重要。近年来,人机界面在系统中所占的比例越来越大,在个别系统中人机界面的设计工作量甚至占设计总量的一半以上。l 人机界面的设计质量,直接影
18、响用户对软件产品的评价,从而影响软件产品的竞争力和寿命,因此,必须对人机界面设计给以足够重视软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 285.5 人机界面设计在设计用户界面的过程中的四个主要问题l系统响应时间l系统响应时间是许多交互式系统用户经常抱怨的问题。一般说来,系统响应时间指从用户完成某个控制动作(例如,按回车键或点击鼠标),到软件给出预期的响应(输出或做动作)之间的这段时间。l系统响应时间有两个重要属性,分别是长度和易变性。l用户帮助设施l几乎交互式系统的每个用户都需要帮助,当遇到复杂问题时甚至需
19、要查看用户手册以寻找答案。大多数现代软件都提供联机帮助设施,这使得用户可以不离开用户界面就解决自己的问题l常见的帮助设施有集成集成的和附加附加的两类。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 295.5 人机界面设计l出错信息处理l出错信息和警告信息,是出现问题时交互式系统给出的“坏消息”。出错信息设计得不好,将向用户提供无用的或误导的信息,反而增加了用户的挫折感。l命令交互l命令行曾经是用户和系统软件交互的最常用方式,而且也曾经广泛地用于各种应用软件中。现在,面向窗口的、点击和拾取方式的界面已经减少了用
20、户对命令行的依赖,但是,许多高级用户仍然偏爱面向命令的交互方式。在多数情况下,用户既可以从菜单中选择软件功能也可以通过键盘命令序列调用软件功能。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 305.5 人机界面设计l 用户界面设计是一个迭代的过程,也就是说,通常先创建设计模型,再用原型实现这个设计模型,并由用户试用和评估,然后根据用户的意见进行修改。l 用户界面设计主要依靠设计者的经验。总结众多设计者的经验而得出的设计指南,有助于设计者设计出友好、高效的人机界面。本节介绍三类人机界面设计指南。软件工程(Sof
21、tware Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 315.5 人机界面设计l一般交互指南:一般交互指南涉及信息显示、数据输入和整体系统控制,因此,这些指南是全局性的,忽略它们将承担较大风险。下面叙述一般交互指南。l保持一致性。l 为人机界面中的菜单选择、命令输入、数据显示以及众多的其他功能,使用一致的格式。l提供有意义的反馈。l 向用户提供视觉的和听觉的反馈,以保证在用户和界面之间建立双向通信。l在执行有较大破坏性的动作之前要求用户确认。l 如果用户要删除一个文件,或覆盖一些重要信息,或请求终止一个程序运行,应该给出“您是否确实
22、要”的信息,以请求用户确认他的命令。l允许取消绝大多数操作。l UNDO或REVERSE功能使众多终端用户避免了大量时间浪费。每个交互式应用系统都应该能方便地取消已完成的操作。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 325.5 人机界面设计l减少在两次操作之间必须记忆的信息量。l 不应该期望用户能记住一大串数字或名字,以便在下一步操作中使用它们。应该尽量减少记忆量。l提高对话、移动和思考的效率。l 应该尽量减少击键次数,设计屏幕布局时应该考虑尽量减少鼠标移动的距离,应该尽量避免出现用户问:“这是什么意思
23、”的情况。l允许犯错误。l 系统应该保护自己不受致命错误的破坏。l按功能对动作分类,并据此设计屏幕布局。l 下拉菜单的一个主要优点就是能按动作类型组织命令。实际上,设计者应该尽力提高命令和动作组织的“内聚性”。l提供对工作内容敏感的帮助设施l用简单动词或动词短语作为命令名。l 过长的命令名难于识别和记忆,也会占据过多的菜单空间软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 335.5 人机界面设计l 信息显示指南:l如果人机界面显示的信息是不完整的,含糊的或难于理解的,则应用软件显然不能满足用户的需求。可以用多
24、种不同方式“显示”信息:用文字、图片和声音;按位置、移动和大小;使用颜色、分辨率和省略。下面是关于信息显示的设计指南。l只显示与当前工作内容有关的信息。l 用户在获得有关系统的特定功能的信息时,不必看到与之无关的数据、菜单和图形。l不要用数据淹没用户,应该用便于用户迅速地吸取信息的方式来表示数据。例如,可以用图形或图表来取代巨大的表格。l使用一致的标记、标准的缩写和可预知的颜色。l 显示的含义应该非常明确,用户不必参照其他信息源就能理解。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 345.5 人机界面设计l
25、允许用户保持可视化的语境。l 如果对图形显示进行缩放,原始的图像应该一直显示着(以缩小的形式放在显示屏的一角),以使用户知道当前观察的图像部分在原图中所处的相对位置。l产生有意义的出错信息l使用大小写、缩进和文本分组以帮助理解。l 人机界面显示的信息大部分是文字,文字的布局和形式对用户从中吸取信息的难易程度有很大影响。l使用窗口分隔不同类型的信息。l 利用窗口用户能够方便地“保存”多种不同类型的信息软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 355.5 人机界面设计l使用“模拟”显示方式表示信息,以使信息更
26、容易被用户吸取。l 例如,显示炼油厂储油罐的压力时,如果使用简单的数字表示压力,则不易引起用户注意。但是,如果用类似温度计的形式来表示压力,用垂直移动和颜色变化来指示危险的压力状况,就能引起用户的警觉,因为这样做为用户提供了绝对和相对两方面的信息l高效率地使用显示屏。l 当使用多窗口时,应该有足够的空间使得每个窗口至少都能显示出一部分。此外,屏幕大小应该选得和应用系统的类型相配套(这实际上是一个系统工程问题)。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 36l 数据输入指南l用户的大部分时间用在选择命令、键
27、入数据和向系统提供输入。在许多应用系统中,键盘仍然是主要的输入介质,但是,鼠标、数字化仪和语音识别系统正迅速地成为重要的输入手段。下面是关于数据输入的设计指南。l尽量减少用户的输入动作。l 最重要的是减少击键次数,这可以用下列方法实现:用鼠标从预定义的一组输入中选一个;用“滑动标尺”在给定的值域中指定输入值;利用宏把一次击键转变成更复杂的输入数据集合。l保持信息显示和数据输入之间的一致性。l 显示的视觉特征(例如,文字大小、颜色和位置)应该与输入域一致。软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 37l 允
28、许用户自定义输入。l专家级的用户可能希望定义自己专用的命令或略去某些类型的警告信息和动作确认,人机界面应该允许用户这样做。l 交互应该是灵活的,并且可调整成用户最喜欢的输入方式l用户类型与喜欢的输入方式有关,秘书可能非常喜欢键盘输入,而经理可能更喜欢使用鼠标之类的点击设备。l 使在当前动作语境中不适用的命令不起作用。l这可使用户不去做那些肯定会导致错误的动作软件工程(Software Engineering)沈阳工业大学信息科学与工程学院沈阳工业大学信息科学与工程学院 魏东 Slide 38l让用户控制交互流。l用户应该能够跳过不必要的动作,改变所需做的动作的顺序(在应用环境允许的前提下),以及在不退出程序的情况下从错误状态中恢复正常。l对所有输入动作都提供帮助l消除冗余的输入。l除非可能发生误解,否则不要要求用户指定工程输入的单位;不要要求用户在整钱数后面键入00;尽可能提供缺省值;绝对不要要求用户提供程序可以自动获得或计算出来的信息。
侵权处理QQ:3464097650--上传资料QQ:3464097650
【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。