ImageVerifierCode 换一换
格式:PPT , 页数:50 ,大小:427KB ,
文档编号:2604353      下载积分:25 文币
快捷下载
登录下载
邮箱/手机:
温馨提示:
系统将以此处填写的邮箱或者手机号生成账号和密码,方便再次下载。 如填写123,账号和密码都是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

优惠套餐
 

温馨提示:若手机下载失败,请复制以下地址【https://www.163wenku.com/d-2604353.html】到电脑浏览器->登陆(账号密码均为手机号或邮箱;不要扫码登陆)->重新下载(不再收费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  
下载须知

1: 试题类文档的标题没说有答案,则无答案;主观题也可能无答案。PPT的音视频可能无法播放。 请谨慎下单,一旦售出,概不退换。
2: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
3: 本文为用户(三亚风情)主动上传,所有收益归该用户。163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

1,本文(软件工程学概述课件第5章详细设计.ppt)为本站会员(三亚风情)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!

软件工程学概述课件第5章详细设计.ppt

1、5.1 5.1 详细设计阶段概述详细设计阶段概述 详细设计的目的详细设计的目的为软件结构图为软件结构图 (SC)(SC) 中的每一个模块确定采用的算法和模块内中的每一个模块确定采用的算法和模块内 数据结构,用某种选定的表达工具给出清数据结构,用某种选定的表达工具给出清 晰的描述。晰的描述。 详细设计阶段的主要任务详细设计阶段的主要任务编写软件编写软件的的 “ “详细设计说明书详细设计说明书” ” 需求分析需求分析问题定义问题定义可性行研究可性行研究计划计划时期时期概要设计概要设计详细设计详细设计编编 码码 测测 试试开发开发时期时期运行与维护运行与维护运运 行行时时 期期详细设计阶段的主要任务

2、为每一模块确定算法确定每一模块使用的数据结构确定模块的外部接口和用户界面为每一模块设计一组测试用例描述工具程序流程图 图 图 伪代码5.2 详细设计阶段的描述工具A1、顺序型一、程序流程图 B几个连续的加工依次序排列expFTA B2、选择型 由某个判断式的取值决定选择两个加工中的一个。3、当型循环型 当循环控制条件成立时,重复执行特定的加工。FT4、直到型循环型 重复执行特定的加工,直到循环控制条件成立时。 FT5、多情况选择型 列出多种加工情况,根据控制变量的取值,选择执行其一。FTTTFF- 具有嵌套形式的程序流程图FTTTFF入口FTFT=1=2=3 标准化程序流程图规定符号 起止端点

3、 输入/输出 一般处理 准备或预处理 预定义处理 条件判断 循环上界 循环下界 文件或文档 外接 内接 流程线虚线 省略线 并行方式 注解或注释 流程符号的使用规则 1、循环符号的使用 循环名进入循环条件循环体 循环名 S=S+i S=0S=S+iS=0,i=1i=i+1 循环体 - 循环流程符号的使用 2、判断有一个入口,但也允许有多个可选出口 A=B AB x=1 x=2 x=3 x=4 =1 =2 =3 =4 =5 - 多出口判断流程符号的使用 请利用程序流程图描述下列问题的程序结构 某汽车修配厂,有一个存有汽车零件的仓库,其中存有若干种零件,请编写一个查询程序,用于查询该库中某零件的库

4、存量为多少。 设该模块为 查询模块。请设计该模块的 程序结构。具体要求: 1、应具有重复查询功能; 2、应具有数据检测功能; 3、请利用程序流程图描述该模块的算法。 顺序型二、 图A B 选择型- Nassi and Shneideman BpFTA ApFT p=1=2=n A1 A2 An do while(p) S do until (p) S 当型循环型 直到型循环型 多分支选择型 零件号100011000210003100041000510006库存量100012508866920203450建立零件库 (s数组), i=0 输入零件号 x do while(x!=s0i)i+i+x

5、=s0i) Y N s0i输出 s1i 输入错误! 继续查询? Y N 跳出循环 三、 图 直到型循环型A BAB A While P SUntil P S 当型循环型 顺序型 选择型A1 A2An 多分支选择型循环型- Problem Analysis Diagrams17s22=0while num(1-1000) 输入 age s17+ s18+ s19+ s20+ s21+ s22+ while i(17-22) 输出 sibegin 请为学生成绩管理系统中的学生成绩统计模块设计程序结构。 要求: 1、统计各专业、各班级的高等数学平均分; 2、并将统计结果输出; 3、按平均成绩以班级为

6、单位由高到低排序; 4、请利用PAD图描述该模块的算法。 四、- Program Ddesign Language是一种用于描述功能模块的算法设计和加工细节的语言。称为设计程序用语言。它是一种伪代码(Pseudo code) -关键词+自然语言(1)、数据说明:格式: TYPE AS 其功能是定义数据的类型和作用域说明: 1. 变量名:是一个模块内部使用的变量或模块间共用 的全局变量名。 2. 限定词1 :标明数据类型 3. 限定词2 :标明该变量的作用域 TYPE number AS STRING LENGTH (12)(2)、程序块: PDL的过程成分是由块结构构成的,而块将作为一个单个的

7、实体来执行。 BEGIN END(3)、子程序结构:把 PDL 中的过程称为子程序。 PROCEDURE INTERFACE END(4)、基本控制结构: IF THEN ; ELSE ; ENDIF - 选择型结构 DO WHILE ; ENDDO REPEAT UNTIL ; ENDREP - 重复型结构 DO LOOP ; EXIT WHEN ENDLOOP DO FOR ; ENDFOR - 重复型结构 - 多路选择结构 CASE OF ; WHEN SELECT ; WHEN SELECT ; DEFAULT: 缺省或错误case: ; ENDCASE READ/WRITE TO -

8、 输入/输出结构 Enter a vector Set Maximum to the value of the first element in the vector DO for each second one to the last IF value of THEN element is greater than the Maximum value Set Maximum to value of the element ENDDO Print the Maximum valueInput array AMax=A(1)DO for I=2 to N IF MaxA(I) Set Max=A

9、(I) ENDIFENDDOPrint Max三、程序复杂性的度量 程序复杂性主要是指模块内部程序的复杂性。它 直接关系到软件开发费用的多少,开发周期的长短和 软件和软件内部潜伏错误的多少。同时它也是软件可 理解性的另一种度量。 它可以用来计算任何一个程序的复杂性; 对于不合理的程序,例如对于长度动态增长的程序, 或者对于原则上无法排错的程序,不应当使用它进行 复杂性计算; 如果程序中指令条数、附加存储量、计算时间增多, 不会减少程序的复杂性。为了度量程序复杂性,要求复杂性度量应满足以下假设: 如果设每行代码的出错率为每100行源程序中可能的错误数目。例如,每行代码的出错率为 1%,也就是说,

10、每 100 行源程序中就可能有一个错误。 1、代码行度量法:统计程序中的源代码的行数较小的程序 -1.3%1.8%/行较大的程序 -2.7%3.2%/行 该方法是利用程序模块的程序图中环路的个数,来计算程序的复杂性的。为此,该方法也称为环路复杂度计算法。 2、McCabe 度量法:利用程序的控制流来度量程序的复杂性 它是一种退化了的程序流程图。即:把程序流程图中每个处理符号都退化成一个结点,而原来流程图中的流程线,则变成连接不同结点的有向弧。(1)程序图符号TC1C2CABED(2)从流程图导出程序图 A开始C1BCED结束C2TF(3)环路复杂性的计算方法 V(G)=m-n+p 说明: V(

11、G) 是有向图G中环路数; m: 为图G中弧数; n: 为图G中节点数; p: 为图G中强连通分量个数; A B C D E F G H K L I McCabe 的环路复杂性度量值为 3请将右侧给出的程序流程图转换为程序图并计算其环路值。a=20b%3=1 b+=3 a+ b-=5TFFT a=0,b=1 程序的环路复杂度则取决于程序控制流的复杂度,也就 是取决于程序结构的复杂程度。当程序内分支或循环个数增 加时,则相应地环域复杂度也随之增加。因此,它是对测试 难度的一种定量度量,也能对软件最终的可靠性给出某种预 测。(4)、环路复杂度的用途 请用程序流程图描述下列问题的算法,再将其转换为程

12、序图并计算其环路值。 请定义一个数组 ,要求找出数组中最大数和最小 数,并把最大数和 中的数对调、最小数和 中的数对调。 请画出下列伪代码程序的流程图、程序图并计算它的环路复杂度。 LOOP : Do While Z0 A=A+1 IF A10 THEN X=A ELSE Y=Z END IF IF Y0 THEN PRINT G E LSE PRINT K END IF STOP 设某模块的功能是:读入任意长的设某模块的功能是:读入任意长的 一段英文课文,将其分解为单字。然后一段英文课文,将其分解为单字。然后 输出一个单词表,并指出每个单词在课输出一个单词表,并指出每个单词在课 文中所出现的

13、次数。文中所出现的次数。 请按下列给出的文字要求,用 PDL 描述其该模块的算法请将下列的 PDL 表示的某模块的过程性描述,改为用:1、N-S 图 2、PAD 图表示5-1 假设只有SEQUENCE和DO-WHILE两种控制结构,怎样利用它们完成IF-THEN-ELSE操作?5-2 假设只允许使用SEQUENCE和IF-THEN-ELSE两种控制结构,怎样利用它们完成DO-WHILE操作?5-3 画出下列伪码程序的程序流程图和盒图:STARTIF p THENWHILE q DOfEND DO ELSEBLOCK g nEND BLOCKEND IFSTOP5-4 图6.18给出的程序流程图

14、代表一个非结构化的程序,请问:(1) 为什么说它是非结构化的?(2) 设计一个等价的结构化程序。图6.18 一个非结构化程序(3) 在(2)题的设计中你使用附加的标志变量flag了吗?若没用,请再设计一个使用flag的程序;若用了,再设计一个不用flag的程序。5-5 研究下面的伪码程序(见书131页):要求:(1) 画出程序流程图。(2) 程序是结构化的吗?说明理由。(3) 若程序是非结构化的,请设计一个等价的结构化程序并且画出程序流程图。(4) 此程序的功能是什么?它完成预定功能有什么隐含的前提条件吗?5-6 用Ashcroft_Manna技术可以将非结构化的程序转换为结构化程序,图6.1

15、9(见书132页)是一个转换的例子。(1) 你能否从这个例子总结出Ashcroft-Manna技术的一些基本方法?(2) 进一步简化图6.19(b)给出的结构化设计。5-7 某交易所规定给经纪人的手续费计算方法如下:总手续费等于基本手续费加上与交易中的每股价格和股数有关的附加手续费。如果交易总金额少于1000元,则基本手续费为交易金额的8.4%;如果交易总金额在1000元到10000元之间,则基本手续费为交易金额的5%,再加34元;如果交易总金额超过10000元,则基本手续费为交易金额的4%加上134元。当每股售价低于14元时,附加手续费为基本手续费的5%,除非买进、卖出的股数不是100的倍数

16、,在这种情况下附加手续费为基本手续费的9%。当每股售价在14元到25元之间时,附加手续费为基本手续费的2%,除非交易的股数不是100的倍数,在这种情况下附加手续费为基本手续费的6%。当每股售价超过25元时,如果交易的股数零散(即,不是100的倍数),则附加手续费为基本手续费的4%,否则附加手续费为基本手续费的1%。要求:(1) 用判定表表示手续费的计算方法;(2) 用判定树表示手续费的计算方法。5-8 画出下列伪码程序(见书132页)的流图,计算它的环形复杂度。你觉得这个程序的逻辑有什么问题吗?5-9 把统计空格程序的Jackson图(图6.13)改画为等价的程序流程图和盒图。5-10 人机对话由操作员信息和系统信息交替组成。假设一段对话总是由操作员信息开始以系统信息结束,请用Jackson图描绘这样的人机对话过程。

侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|