 
         
         
         
         
         下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、软件工程导论课后习题答案第一章软件工程概论1-11 .什么是软件危机?软件危机是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。这 些问题表现在以下几个方面:(1)用户对开发出的软件很难满意。(2)软件产品的质量往往靠不住。(3) 一般软件很难维护。(4)软件生产效率很低。(5)软件开发成本越来越大。(6)软件成本与开发进度难以估计。(7)软件技术的发展远远满足不了计算机应用的普及与深入的需要。2 .软件危机有那些典型表现?(1)对软件开发成本和进度的估计常常很不准确。(2)用户对口完成的”软件系统不满意的现象经常发生。(3)软件产品的质量往往靠不住。(4)软件常常是不可维护的。(5)
2、软件通常没有适当的文档资料。(6)软件成本在计算机系统总成本中所占的比例逐年上升。(7)软件开发生产率提高的速度,远远跟不上计算机应用迅速普及深入的趋势。3 .为什么会产生软件危机?(1)开发人员方面,对软件产品缺乏正确认识,没有真正理解软件产品是一个完整 的配置组成。造成开发中制定计划盲目、编程草率,不考虑维护工作的必要性。(2)软件本身方面,对于计算机系统来说,软件是逻辑部件,软件开发过程没有统 一的、公认的方法论和规范指导,造成软件维护困难。(3)尤其是随着软件规模越来越大,复杂程度越来越高,原有软件开发方式效率不 高、质量不能保证、成本过高、研制周期不易估计、维护困难等一系列问题更为突
3、 出,技术的发展已经远远不能适应社会需求。4 .怎样克服软件危机?(1)充分吸收和借鉴人类长期以来从事各种工程项目中积累的行之有效的有效原理、概念、技术与方法,特别是吸取几十年来人类从事计算机硬件研究和开发的经验教训。在开发软件的过程中努力作到良好的组织,严格的管理,相互友好的协作。(2)推广在实践中总结出来的开发软件的成功的技术和方法,并研究更好、更有效 的技术和方法,尽快克服在计算机系统早期发展阶段形成的一些错误概念和作法。(3)根据不同的应用领域,开发更好的软件工具并使用这些工具。将软件开发各个 阶段使用的软件工具集合成一个整体,形成一个很好的软件开发支环环境。总之为了解决软件危机,既要
4、有技术措施(方法和工具),又要有必要的组织管理措施。1-3、1-5、根据历史数据可以做出如下的假设:对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:M=4080e0.28(Y-1960)存储器的价格按下面公式描述的趋势逐年下降:P1=0.3 X 0.72Y-1974(美分/位)如果计算机字长为16位,则存储器价格下降的趋势为:P2=0.048X0.72Y-1974(美元/字)在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。基于上述假设可以比较计算机硬件和软件成本的变化趋势。要求计算:(1)在1985年对计算机存储容量的需求估计是多少 ?如果字长为16位,这个存储 器的
5、价格是多少?(2)假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月 4000美元。如果一条指令为一个字长,计算使存储器装满程序所需用的成本。(3)假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序 员的月平均工资为6000美元,重复(1)、(2)题。 (1)在1985年对计算机存储容量的需求,估计是M = 4080e°28C1M5-1960) = 4080 J =4,474,263(字) 如果字长为16位,则这个存储器的价格是_P - 0.048 x 0.721,回I* x 4474263 - 5,789(美元) (2)如果一条指令的长
6、度为一个字,则使存储器装满程序共 需4474263条指令. 在1985年一名程序员每天可开发出10条指令,如果每月 有20个工作日,则每人每月可开发出10X20条指令. 为了开发出4474263条指令以装满存储器,需要的匚作量是:4474263200十22371(人月)程序员的月平均工资是4000美元,开发出4474263条指 令的成本是 22371x4000 = 89,484,000(美元) (3)在1995年对存储容量的需求估计为:M = 4080e° 想= 7茎71679(字)40g 窕叱 如果字兴为32位,则这个存储器的价格是;_P = 0.003x 32x O.721995
7、x 73577679= 7,127(7E) 如果一条指令为一个字长,则为使存储器装满程序共需 73,577,679 条指令. 在1995年一名程序员每天可开发出30条指令,每月可开 发出600条指令,为了开发出可装满整个存储器的程序, 需要的工作量为-7767二式人月)600开发上述程序的成本为;122629x6000 + 735,776790(美元)1-6什么是软件过程?它与软件工程方法学有何关系 ?软件过程是为了开发出高质量的软件产品所需完成的一系列任务的框架,它规定了完成各项任务的工作步骤。软件过程定义了运用技术方法的顺序、应该交付的文档资料、为保证软件质量和协调软件变化必须采取的管理措
8、施,以及标志完成了相应开发活动的里程碑。软件过程是软件工程方法学的3 个重要组成部分之一。4. 构成软件项目的最终产品:应用程序、系统程序、面向用户的文档资料和面向开发者的文档资料。5什么是软件生存周期?软件生存周期是指从软件定义、开发、使用、维护到淘汰的全过程。6软件生存周期为什么划分成阶段?(1) 任何一个阶段的具体任务不仅独立,而且简单,便于不同人员分工协作, 从而降低整个软件开发工作的困难程度。(2) 可以降低每个阶段任务的复杂程度,简化不同阶段的联系,有利于工程的 组织管理,也便于采用良好的技术方法。(3) 使软件开发的全过程以一种有条不紊的方式进行,保证软件的质量,特别 是提高了软
9、件的可维护性。7应该怎样来划分阶段?(1) 每一个阶段的任务尽可能独立;(2) 同一阶段内的任务性质尽可能相同;(3) 每一个阶段任务的开始和结束有严格的标准。8软件开发模型有几种?它们的开发方法有可特点?软件开发模型有瀑布型、渐增型和变换型。瀑布型开发方法是按照软件生存周期的划分依次实施,每一个阶段有明确规定的任务。它的特点:(1) 各个阶段的顺序性和依赖性;(2) 划分逻辑设计与物理设计,尽可能推迟程序的物理实现;(3) 每个阶段必须完成规定的文档,对其中问题通过复审及早发现,及早解决。渐增型开发方法及特点:(1) 从部分需求出发,先建立一个不完全的系统,通过测试运行该系统取得经验和信息反
10、馈,加深对软件需求的理解,进一步使系统扩充和完善。如此反复,直至软件人员和用户对所设计完成的软件系统满意为止。(2) 在渐增型开发下的软件是随软件开发的过程而逐渐形成的。(3) 渐增型开发方法适合于知识型软件的开发,设计系统时对用户需求的认识开始不是很清楚的,需要在开发过程中不断认识、不断获得新的知识去丰富和完善系统。多数研究性质的试验软件,一般采用此方法。变换型开发方法及特点:(1) 从软件需求的形式化规格说明出发,经过一系列的程序变换,得到最终的程序系统。(2) 该方法必须有严格的数学理论和形式化技术的支持。9. 什么是软件工程?软件工程是指导计算机软件开发和维护的工程学科。(1) 它采用
11、工程的概念、原理、技术和方法来开发和维护软件;(2) 它将管理技术与当前经过时间考验的而证明是正确的技术方法结合起来;(3) 它强调使用生存周期方法学和结构分析和结构技术;(4) 经过人们长期的努力和探索,围绕着实现软件优质高产这个目标, 从技术到管理两个方面做了大量的努力, 逐渐形成了"软件工程学"这一新的学科。10什么是软件工程环境:方法与工具的结合,加上配套的软、硬件支持称为软件工程环境。它能支持开发者按照软件工程的方法, 全面完成生存周期中的各项任务。第二章 可行性研究习题答案1. 问题定义的任务和主要工作?问题定义的任务:将用户提出的要求具体化、定量化;确定研制系
12、统的范围,明确研制的边界。问题定义阶段的工作:(1) 通过调查研究,了解系统需求;(2) 确定系统的功能需求、性能需求、可靠性需求、安全及保密性、资源、开发费用及开发进度等的需求;(3) 问题定义阶段的产品- 系统目标与范围说明书。2. 可行性研究目的?确定在问题定义中所提出的问题是否值得去解,在限制条件下,问题能否解决。3可行性研究的任务?(1) 进一步分析和澄清问题的定义,在澄清问题的基础上,导出系统的逻辑模型;(2) 从系统逻辑模型中,选择问题的若干种主要解法,研究每一种解法的可行性,为以后的行动提出建议;(3) 如果问题没有可行的解,建议停止系统开发;如果问题有可行的解,应该推荐一个较
13、好的解决方案,并为工程制定一个初步的计划。4可行性研究包括哪几方面的内容?(1) 技术可行性:现有技术能否实现本系统,现有技术人员能否胜任,开发系统的资源能否满足;(2) 经济可行性:经济效益是否超出开发成本;(3) 操作可行性:系统操作在用户内部行得通吗?(4) 法律可行性:新系统开发是否会侵犯他人、集体或国家利益,是否违反国家法律。5可行性研究的步骤?(1) 复查系统的规模和目标;(2)研究目前正在使用的系统,总结现有系统的优劣,提出新系统的雏形;(3)导出新系统的高层逻辑模型;(4)推荐建议方案;(5)推荐行动方针;(6)书写计划任务书(可行性报告);(7)提交审查。6.可行性研究报告的
14、主要内容?可行性分析的结果是可行性研究报告,内容包括:(1)系统概述:说明开发的系统名称,提出单位和开发单位。(2)可行性研究的前提:系统目标;要求;约束和限制;可行性研究的基本 准则等。(3)对现有系统的分析:处理流程,图示说明现有系统的处理流程和数据流 程;现有系统存在的问题。(4)系统需求:主要功能;主要性能及其要求;操作要求;信息要求;限制 性要求。(5)建议系统:系统目标;处理流程;系统结构,功能,性能;系统技术可行 性;投资和效益分析;操作可行性;法律可行性。(6)其它可选方案:与国内外同类型方案的比较;提出一两个可行性方案供 论证和探讨。(7)制定下一阶段的预算。(8)结论性意见
15、:由用户方、设计方和投资方共同签署意见。2-4目前住院病人主要由护士护理,这样做不仅需要大量护士,而且由于不能 随时观察危重病人的病情变化,还会延误抢救时机。某医院打算开发一个以计算机 为中心的患者监护系统,请分层次地画出描述本系统功能的数据流图。医院对患者8监护系统的基本要求是随时接收每个病人的生理信号(脉搏、体 温、血压、心电图等),定时记录病人情况以形成患者日志,当某个病人的生理信号 超出医生规定的安全范围时向值班护士发出警告信息,此外,护士在需要时还可以 要求系统印出某个指定病人的病情报告。从问题陈述可知,本系统数据源点是“病人”和“护士”,他们分别提供生理信号 和要求病情报告的信息。
16、进一步分析问题陈述,从系统应该“定时记录病人情况以 形成患者日志”这项要求可以想到,还应该有一个提供日期和时间信息的“时钟” 作为数据源点。从问题陈述容易看出,本系统的数据终点是接收警告信息和病情报告的护士。系统对病人生理信号的处理功能主要是“接收信号”、“分析信号”和“产生警告信息”。此外,系统还应该具有“定时取样生理信号”、“更新日志”和“产生病情报告” 的功能。为了分析病人生理信号是否超出了医生规定的安全范围,应该存储“患者安全范围”信息。此外,定时记录病人生理信号所形成的“患者日志”,显然也是一个数据存 储。E2病人F2生理信号P2分析信号L;II危及病人信息 F2生理信-|F5安全范
17、围F2生理信号一D3生理信息P1D2患者安全范围it定时的生理信号F4警告信息,P5更新日志i ?P3产生警告信息E1护士接收信号 F2生理信号定时的 生理信号2-5北京某高校可用的电话号码有以下几类:校内电话号码由4位数字组成,第1位数字不是0;校外电话又分为本市电话和外地电话两类,拨校外电15需先拨0,若是本市电话则再接着拨8位数字(第1位不是0),若是外地电话则拨3位区码再拨8 位电话号码(第1位不是0)。请用定义数据字典的方法,定义上述的电话号码。数据结构的描述符号含义 举 例=被定义为+与 x = a + b,或|或 x = a , b , x = a | b . 或 mn重复 x
18、= a, x = 3a8(.)可选 x = (a)“”基本数据元素 x =“a”连结符 x = 1.9电话号码二校内电话号码|校外电话号码校内电话号码=非零数字+ 3位数字/后面继续定义 校外电话号码=本市号码|外地号码本市号码=数字零+8位数字外地号码=数字零+3位数字+8位数字非零数字二1|2|3|4|5|6|7|8|9数字零=03位数字=3数字3/3 至3个数字8位数字=非零数字+7位数字7位数字=7数字7数字=0|1|2|3|4|5|6|7|8|9第三章需求分析习题答案1 .需求分析的描述工具有哪些?有数据流图、数据字典、判定表、判定树、结构化自然语言、层次方框图、Warnier 图、
19、IPO图和需求描述语言等。2 .需求分析的基本任务是什么?准确定义未来系统的目标,确定为了满足用户的需要系统必须做什么3 .怎样建立目标系统的逻辑模型?要经过哪些步骤?建立目标系统的逻辑模型的过程也就是数据流图的分解过程。它的导出过程如 图:4 .什么是结构化分析?它的结构化体现在哪里?结构化分析:使用数据流程图、数据字典、结构化英语、判定表和判定树等工具, 来建立一种新的、称为结构化说明书的目标文档-需求规格说明书。结构化体现在将软件系统抽象为一系列的逻辑加工单元,各单元之间以数据流发生关联。5 .软件需求规格说明书由哪些部分组成 ?组成包括:(1)引言:编写目的、背景说明、术语定义及参考资
20、料等。(2)概述主要功能、约束条件或特殊需求。(3)数据流图与数据字典。(4)用户接口、硬件接口及软件接口。(5)性能需求、属性等。(6)其它需求,如数据库、操作及故障处理等。6 .为什么数据流图要分层?画分层的DFD要遵循哪些原则? 分层的目的:便于逐步细化、结构清晰。画分层的DFDg遵循哪些原则:(1)父图与子图之间数据要平衡。(2)分解的深度和层次达到使加工足够简单、易于理解的基本加工为止。(3)区分局部文件和局部外部项(局限于数据流中某一层或某几层的文件和外部项)(4)不要把控制流作为数据流。(5)忽略琐碎的枝节。(6)每个数据流要有一个合适的名字,尽量使用现实系统中有具体意义的名字7
21、 .系统流程图与数据流程图有什么区别 ?系统流程图描述系统物理模型的工具,数据流程图描述系统逻辑模型的工具。系统流程图从系统功能的角度抽象的描述系统的各个部分及其相互之间信息流 动的情况。数据流程图从数据传送和加工的角度抽象的描述信息在系统中的流动和数据处 理的工作状况。8.数据字典包括哪些内容?已的作用是H么4耳成分:E1据字典左棍|蝴海40辅曾廉得j勺集合JF3特策据流上每一 .一数网文,肘TW滕数日数据加:/据存屑F4和皿楙顼等合以盛义和说明;它主要由数如流描述、加工w述和文件描斗三部分组成。 们提供了数据的明确定学5存诙楠分四界楸立的系统逻辑模型。/111、对用户来讲,数据年典为他数据
22、字典帮助他们比较容易修改已建9 .描述加工逻辑的工具有哪些口的款信息有决策树(又一判定树)、决第麦(又称判断表)和结构化语言等。3-3银行计算 员键无1统,存款维艰 存I而斯7嗨蒯住址(或他话份证号码、训选)等信息,圣W单给储户;如果是取款而H存款时留有密码,则系统并先核对储户密码,卷密码正峭3争隅时 未留密J 5- »、inw 乂"工ll七班金白码,请用则系统计算利息并印出个身荐缴般产F5存款信息数据流图描绘本系统的功能,并用手体D1存款信息F7密码F2取款单-联系图描绘系统F4利息E1的数据对象储尸F5存款信息F4利息一F4 矛 |息P5打印利息清单S 一一PP6F8储
23、畜利率 > 设置利率一F8储畜利率4 D2存款利率 排除了卡纸故障广复印命令一 (闲置厂二"= 完成复印命令卡纸警告豆印3-6复印机do/复印优态,一旦接到复印缺纸内工作过程大致如下:未接到复印命令时处命令则进入I叁印状态,完成装潢继印命令规定的工作后又回到个复印命令;如果执行复印命令时发现没纸,则进入缺纸状态I发出下一待装纸,装满纸后进入闲置状态,准备接收复印命令;如果复印时发生卡纸故障,则进 入卡纸状态,发出警告等待维修人员来排除故障,故障排除后回到闲置状态。请用状态转换图描绘复印机的行为。从问题陈述可知,复印机的状态主要有“闲置”、“复印”、“缺纸”和“卡纸”。引起状态转
24、换的事件主要是“复印命令”、“完成复印命令”、“发现缺纸”、“装 满纸”、“发生卡纸故障”和“排除了卡纸故障”第五章 总体设计习题答案1. 系统设计包括哪两个阶段?系统设计包括总体设计与详细设计两个阶段。2. 总体设计的主要任务是什么?总体设计的主要任务是完成软件结构的设计, 确定系统的模块及其模块之间的关系。3. 什么是模块?模块具有哪几个特征?总体设计主要考虑什么特征?模块是数据说明、可执行语句等程序对象的集合,可以单独命名且可通过名字来访问。模块具有输入和输出( 参数传递) 、功能、内部数据结构( 局部变量) 和程序代码四个特性。概要设计主要考虑输入、输出( 参数传递) 和功能两个特性。
25、4. 什么是模块化?模块设计的准则?模块化是按规定的原则将一个大型软件划分为一个个较小的、相对独立但又相关的模块。模块设计的准则:(1) 改进软件结构, 提高模块独立性: 在对初步模块进行合并、分解和移动的分析、精化过程中力求提高模块的内聚,降低藕合。(2) 模块大小要适中: 大约 50 行语句的代码,过大的模块应分解以提高理解性和可维护性; 过小的模块, 合并到上级模块中。(3) 软件结构图的深度、宽度、扇入和扇出要适当。一般模块的调用个数不要超过5 个。(4) 尽量降低模块接口的复杂程度;(5) 设计单入口、单出口的模块。(6) 模块的作用域应在控制域之内。5. 变换型数据流由哪几部分组成
26、?变换型结构由三部分组成: 传入路径、变换( 加工 ) 中心和传出路径。6. 变换分析设计的步骤?(1)区分传入、传出和变换中心三部分,划分DFDS的分界线;(2)完成第一级分解:建立初始SC图的框架;(3)完成第二级分解:分解SC图的各个分支;(4)对初始结构图按照设计准则进行精化与改进。7. 事务型数据流由哪几部分组成?事务型结构由至少一条接受路径、一个事务中心与若干条动作路径组成。8. 事务分析设计的步骤?(1)在DFD图中确定事务中心、接收部分(包含全部接收路径)和发送部分(包含全部动作路径);(2)画出SC图框架,把DFD图的三部分分?quot;映射"为事务控制模块,接 收
27、模块和动作发送模块.一般彳#到SC图的顶层和第一层(如果第一层简单可以并入 顶层);(3)分解和细化接收分支和动作分支,完成初始的SC图;(4)对初始结构图按照设计准则进行精化与改进。9. 比较层次方框图与结构图是的异同?(1)层次方框图描绘数据的层次结构,结构图描绘的是软件结构。(2)二者都采用多层次矩形框树形结构。层次方框图的顶层矩形框代表完 整的数据结构,下面各层矩形框依次代表上个框数据的子集;结构图是在层次图的每一个方框内注明模块的名字或主要功能,方框之间的直线表示模块的调用关 系,用带注解的箭头表示模块调用过程中传递的信息。10. 欲开发一个银行的活期存取款业务的处理系统:储户将填好
28、的存/取款单和存折交给银行工作人员,然后由系统作以下处理;(1)业务分类处理:系统首先根据储户所填的存 /取款单,确定本次业务的 性质,并将存/取款单和存折交下一步处理;(2)存款处理:系统将存款单上的存款金额分别记录在存折和帐目文件中,并将现金存入现金库;最后将存折还给储户;(3)取款处理:系统将取款单上的取款金额分别记录在存折和帐目文件中, 并从现金库提取现金;最后将现金和存折还给储户。绘制该系统的数据流图和软件结构图。顶层一层软件结构图本问题中共有三类实体,分别是“零件”、“工程项目”和“供应商”。一种零件可供应多个工程项目,一个工程项目需要使用多种零件,因此,零件 与工程项目之间的联系
29、“供应”,是多对多( M ' N )联系;类似地,零件与供应 商之间的联系“订购”,也是多对多( M ' N )联系。实体类型“零件”的主要属性是:零件编号,零件名称,颜色,重量。实体类 型“工程项目”的属性主要是:项目编号,项目名称,开工日期。实体类型“供应 商”的属性主要有:供应商编号,供应商名称,地址。联系类型“供应”的属性是, 向某工程项目供应的某种零件的数量。联系类型“订购”的属性是,向某供应商订 购的某种零件的数量。补充方 某火车售票系统的数据流程图如下所示D3配件库存合格订货合格订货单存储订暂存订货发货产生发货定货系统D图如下,请按SD,暂存订货单配件库存&quo
30、t;暂存订赞单处理顾客订货33格订货单账款信息订货单编辑订 货单获取订 货单获取配 件信息获取配件 库存订货单合格订货产生销售 史补充3、已知某定货系统I 方法的设计步骤画出结配件库存单合格订货均'发货单产生应收漾 明细帐川一;暂存订货以D4智仔”货单4一 D4暂存订货单心、re获取订货2 库存信息输出订信1获取顾 客信息销售信5-3用面向数据流的方法设计下列系统的软件结构(1)储蓄系统2-2(2)机票预定系统2-3为了方便旅客,某航空公司拟开发一个机票预定系统。旅行社把预定机票的旅 客信息(姓名、性别、工作单位、身份证号码、旅行时间、旅行目的地等)输入该 系统,系统为旅客安排航班,旅
31、客在飞机起飞前一天凭取票通知和账单交款取票, 系统核对无误即印出机票给顾客(2)患者监护系统2-4银行储蓄源统业务单据录 入单据输出存单利息清单F7密码E1储户E1储户利息利息工_L“P5 、打印利息I清单_)E1储 户E2业务员机票旅客信息预定信息旅客信息旅行社旅客信息航班信息航班信息P1录入预定信息 J取票通知P2安排航班J账单顾客取票通知取票通知机票账单账单机票取票通知一机票一/P3顾客取票V机票一机票*单 事 通机票预定系审信息息 予巧痣过机票预定子系统机票发放子系统预定信息处理息信班航安排航班打印取票单据取票凭证处 理打印及发放 机票设置航班录入预定信息录入取票凭证核对取票凭证5-4
32、美国所有年工资超患者监护系统dli氾信生/产下.生叁寸JE患者生理信号获取200监护处理名教师,校邛与H年者刚刚签订白监护信息输出,$26000” $26000 )地教和资将J呆持不变,组工|资卜于 的教师将枷工滂口听妈蚓嚓斜额按,>“'口»按照协议,一R涉电计侏日防每位教师雌如勺人'位中教师|本人)?其补|劝$100山外 教师一什j扁年1g多补臂¥ 堀帷而蟀4M正阳 建2600钟费微51狷当螂辆I相处理修I野1日 $2600050,但尾,增N前的年报赞赠养创t报数、雇佣日期等信息。需要写一个程序计算并印出每名教师的原工资和调整后的新要求:(1)画出此
33、系统的数据流(3)设计上述的工资调戢称忻问(冬;(2)写出需求说明;要求用HIPO图描绘设计结果),设计时分别采用两种算法,并比较两种拿话附优也(a)搜索工资档案数据,找出年工资少于 $26000的人,计算新工资,校核是调资后工资档案调资后工资档案E1行政办公室工资档案一.回答问题1 .详细设计的目的?为软件结构图(SC图或HC图)中的每一个模块确定采用的算法和块内数据结构,用某种选定的表达工具给出清晰的描述.2 .详细设计的主要任务?编写软件的“详细设计说明书”.软件人员要完成的工作:(1) 为每一个模块确定采用的算法,选择某种适当的工具表达算法的过程,写出模块的详细过程描述.(2) 确定每
34、一模块使用的数据结构.(3) 确定模块结构的细节,包括对系统外部的接口和用户界面,对系统内部其它模块的接口,以及关于模块输入数据、输出数据及局部数据的全部细节.(4) 为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定的测试.3. 结构化程序设计的基本原则?在详细设计中所有模块都使用单入口、单出口的顺序、选择、循环三种基本控制结构 .4. 比较面向数据流和面向数据结构两类设计方法的异同?相同点:(1) 遵守结构程序设计“由顶向下”逐步细化的原则 , 并以其为共同的基础;(2) 均服从“程序结构必须适应问题结构”的基本原则 , 各自拥有从问题结构( 包括数据结构) 导出程
35、序结构的一组映射规则。不同点:1) )面向数据流的设计以数据流图为基础,在分析阶段用DFD8示软件的逻辑模型,在设计阶段按数据流类型,将数据流图转换为软件结构。面向数据结构的设计以数据结构为基础,从问题的数据结构出发导出它的程序结构。2) )面向数据流的设计的最终目标是软件的最终SC图,面向数据结构的设计的最终目标是程序的过程性描述。5) 比较Jackson方法和LCP方法的异同?Jackson与LCP设计方法都是以数据结构为出发点,以程序的过程描述为最终目标,设计步骤基本相似。它们的主要差别是:(1)使用不同的表达工具,其中 LCP方法中的表达工具 Warnier图比 Jackson 设计方
36、法中的表达工具Jackson 图有更大的通用性;(2)Jackson方法的步骤和指导原则有一定的灵活性,而LCP设计方法则更加严密。6) 详细设计的描述工具应具备什么功能?无论哪类描述工具不仅要具有描述设计过程,如控制流程、处理功能、数据组织及其它方面的细节的能力, 而且在编码阶段能够直接将它翻译为用程序设计语言书写的源程序。二 . 给出一组数从小到大的排序算法,分别用下列工具描述其详细过程:(1) (1) 流程图;(2)NS 图;(3)PAD 图;(4)PDL 语言。PDL语言略PAD图三.根据后面给出“卡片的分类及统计”项目说明,完成下列工作:(1)用Jackson图表示输入与输出数据结构
37、,找出它们之间的对应单元;(2) 画出用Jackson图表示的程序结构;(3)列出程序所需用的操作,并加到上一步画出的程序结构图上;(4)用Jackson伪代码写出程序的过程表示。输入卡片分析程序。一叠输入卡片按内容分为 K1、K2、K3三类,卡片的排列规则 是:以K1卡始,以K2卡终。起始卡之前属前置部分,不含K1卡;起始卡与终了卡 之间属分批部分,不含K2卡。如图:试用Jackson方法编一程序,要求依次完成下列分析工作:- -统计起始卡前卡片的张数,存入A;打印起始卡的内容;- -统计起始卡后出现的K1卡和K3卡总批数,存入B;- -统计起始卡后出现的K1卡的张数,存入C;- -统计起始
38、卡后出现的K3卡的批数,存入D;- -打印终了卡的内容;- -打印A、B、C、D四个统计值。输入卡片文件的数据结构图输出卡片文件的数据结构上述两个结构图有三组对应单元: 顶层单元、起始卡单元和终了卡单元. 按映射规则,可导出下页程序结构图.卧理批由上步导出的程阴吉构处理K3卡”将输入早曲山山山丽橙块细 |一瑁批部分1处理批体程序的过程表示及伪代码略处理批部分处理。卡*处理批*处理K1卡*统计犹数输入卡片文件丁口门 a. eraNE加始,初八处理前置部分处理殿卡*L.I -rtl . 8率统计张数公理批英统计总批数处理K1卡率处理五珊口处理KI批0处理R1批°疏计张数6-3回出下列伪码
39、程序的程序流程图和盒图 STARTIF p THEN WHILE q DO fEND DOELSEBLOCKg nEND BLOCKEND IFSTOP开始)4下图给出的程序流程图代表一个非结构化的程序,请问:(1)为什么说它是非结构化的?(2)设计一个等价的结构化程序。(3)在(2)题的设计中你使用附加的标志变量 flag吗?若没用,请再设计一个使用flag的程序;若用了,再设计一个不用flag的程序(1)通常所说的结构化程序,是按照狭义的结构程序的定义衡量,符合定义规定的程序。图示的程序的循环控制结构有两个出口 ,显然不符合狭义的结构程序的定义,因此是非结构化的程序。(2)使用附加的标志变
40、量flag ,至少有两种方法可以把该程序改造为等价的结构 化程序,图示盒图描绘了等价的结构化程序。不使用flag把该程序改造为等价的结构化程序的方法如图所示p/g(NOT p)OR(NOTq)6-8画出下列伪码程序的流图,计算它的环形复杂度。你觉得这个程序的逻辑有 什么问题吗?C EXAMPLELOOP:DO WHILE X>0A=B+1IF A>10THEN X=AELSE Y=ZEND IFIF Y<5THEN PRINT X,YELSE IF Y=2THEN GOTO LOOPELSE C=3END IFEND IFG=H+REND DOIF F>0THEN PR
41、INT GELSE PRINT K END IF=17-11+1=7=判断结点+1=6+1 = 7=封闭的区域数充1、某高校研究生招生系统的初选方法如下:总分 300 (含)以上进入候选学 生库,否则退档;数学分数不低于 70分,则进入三级备选库,否则进入四级备 选库;在三级备选库的基础上,如果专业课分数高于100分,则进入一级备选库, 否则进入二级备选库,请画出对应的判定树。二一蹑区专业3100一恕庇专业W100二四库补充2、某校的课酬计算方案如下:(l)基本课酬为每节课10元;(2)如果班级 人数超过40人,课酬增加:基本课酬X 0.1 ; (3)如果班级人数超过60人,课酬 增加:基本课
42、酬X 0.2; (4)如果教师是副教授,课酬增加:基本课酬X 0.1; (5) 如果教师是教授,课酬增加:基本课酬X 0.2; (6)讲师,课酬不增加;(7)助教, 课酬减少:基本课酬X 0.1。请用判定表表达上述计算方案。123456789101112人数W4OTTTT4AV人数TTTT人数601,TTTr助教TTI1讲帅TTT副教授TrT教授TTT课酬9元/节课潮± 1。元VV课篇:11元/节44课制二12元/节VVV源前工13疝WVV课事工14元/节4第七章 习题参考答案1. 编码的任务?使用选定的程序设计语言,把模块的过程性描述翻译为用语言书写的源程序( 源代码 ) 。2.
43、对源程序基本要求?源程序要求:正确可靠、简明清晰、效率高。(1) 源程序的正确性是对程序质量的最基本要求;(2) 源程序的简明清晰,便于验证源代码和模块规格说明的一致性,容易进行测试和维护;(3) 对于大多数模块,编码时应该把简明清晰放在第一位;(4) 除了编码阶段产生源代码外,在测试阶段也需要编写一些测试程序,用于对软件的测试。3. 程序设计语言的特点?(1) 名字说明:程序中使用对象的名字,能为编译程序所检查和识别;(2) 类型说明:定义对象的类型,确定该对象的使用方式;(3) 初始化:为变量提供适当的初始值或由系统给变量赋一特殊的表明未初始化的值;(4) 对象的局部性:程序中真正需要的那
44、部分才能访问的对象;(5) 程序模块:控制程序对象的名字;(6) 循环控制结构:如FOR、WHILE-DO©句、REPEAT-UNTI语句等;(7) 分支控制结构:如IF语句、CAS印句等;(8) 异常处理:为程序运行过程中发生的错误和意外事件提供检测和处理上的帮助;(9) 独立编译:能分别编译各个程序单元。4. 选择程序设计语言需要考虑的因素?(1) 选择用户熟悉、便于用户维护的语言。(2) 选择目标系统的环境中可以提供的编译程序所能选用的语言。(3) 选择可以得到的软件工具,能支持程序开发中可以利用的语言。(4) 根据工程规模的大小、目标系统应用范围,如实时应用选择Ada语言或汇
45、编语言,系统软件开发选择C语言或汇编语言,软件开发中若含有大量数据操 作则选择SQL dBAS堂数据库语言等。(5) 选择程序员熟悉的语言。(6) 选择标准化程度高、程序可移植性好的语言。(7) 根据算法与计算的复杂性、数据结构的复杂性选择。如对于系统程序和结构复杂的应用程序,选择支持数组、记录( 或结构 ) 与指针动态数据结构的Pascal |EE|Cim。(8) 根据实时要求系统需要的响应速度和效率选择相应的语言。5. 编码风格的指导原则。(1) 源程序: 包括适当的标识符、适当的注解、程序清单的合理布局与清晰;(2) 数据说明:数据结构或数据类型的说明次序标准化;变量名称尽量有意义;对复
46、杂的数据结构在注解中要说明在程序设计中实现这个数据结构的方法。(3) 语句的构造简单明了:不要为节省空间将多个语句写在同一行;尽量避免复杂的条件及“非”条件的测试;避免大量使用循环嵌套和条件嵌套;括号的使用是为了使逻辑表达式和算术表达式的运算顺序清晰直观。(4) 效率: 考虑程序运行的时间存储器效率、输入 /输出的效率;在处理程序正确性、 清晰与效率之间的关系时先求程序正确后求快;先求清楚后求快;保持程序简单以求快;书写清楚, 不为“效率”牺牲清晰。6. 第四代语言(4GL)应具备哪些的特征?(1) 具有很强的数据管理能力,能对数据库进行有效的存取、查询和其它有关操作;(2) 能提供一组高效的
47、、非过程化的命令,组成语言的基本语句,编程时用户只需用这些命令说明“做什么”,不必描述实现的细节;(3) 能满足多功能、一体化的要求。为此,语言中除必须含有控制程序逻辑与实现数据库操作的语句外,还应包括生成与处理报表、表格、图形,以及实现数据运算和分析统计功能的各种语句, 共同构成一个一体化的语言,以适应多种 应用开发的需要。修改石表中其程序结构.改进如下程序的结相if(A>B)thenzf (X>T)+hpn比=/:els5A:=I;rnJi£elss|s炉;口cudif;将如下的要出口指环给枸改为单出口程屏吉构科二LE Cl DQBEGINft. IF C2 TEEN
48、 GOTO 30;F-l I止二3 TEEN GOTO 30;HNT<:cjdt fui C2 tiKitJGOTO 40i90:(code for C3 txit)40:改进后时程严辐格,if(A<B= tienif (Z>Y)时a:=Yselseeiidif ;鼓迷后的单出口程序结构e'iiTl:=falrG txit2t=falrfr,WILE Cl ANIi 0IOT exlrl) ANIi (NOT3EGINF > I:IF C2 THEN exilll- ULLt:;IF C3 TFEN erit2:=true(E即;IF (exitll THEN
49、GOTO 2D;IF (=xlt2j TLEN GOTO 3D;20: cede far CZ ex工廿GOTO 硬:30: code fox C54。;7- 4(3)、设计下列伪码程序的语句覆盖和路径覆盖测试用例:STARTINPUT (A, B, C)/判定表达式1IF A>5 THENX=10ELSEX=1END IF/判定表达式2IF B>10 THENY=20ELSEY=2END IF/判定表达式3IF C>15 THENZ=30ELSEZ=3END IFPRINT (X, Y, Z) STOP语句覆盖的测试用例序 号刘定输入预期的输 出123ABCXYZ1FFF1111232TTT204060102030路径覆盖的测试用例序号判定输入皎期的输出123ABCXYZ1FFF1111232FFT116012303FTF140112034FTT1441601211305TFF201110236TFT20160102307TTF如如110203*TTT204060102030第七章习题参考答案一 . 回答问题1. 软件测试的基本任务?软件测试是按照特定的规则,发现软件错误的过程;好的测试方案是尽可能发现迄今尚
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 施工安全风险评估与应急响应方案
- 钢结构BIM建模与施工模拟方案
- 2025贵州黔西南州安龙县县属国有企业招聘高级管理人员8人笔试历年参考题库附带答案详解
- 2025泰康医疗校园招聘笔试历年参考题库附带答案详解
- 空中物流区域安全管理方案
- 2025中国铁塔股份有限公司宁德市分公司招聘实习生笔试历年参考题库附带答案详解
- 2025年永嘉小学语文真题及答案
- 照明设施智能调光与能耗监控方案
- 水库水污染治理与生态修复工程方案
- 企业年度财务管理与预算执行总结
- 2025年评标专家考试题库题及答案
- 铭记历史+勿忘国耻:从电影《731》看民族记忆-2025-2026学年高中上学期主题班会
- 总务人员考试试题及答案
- 2025年甘肃省庆阳市公安局面向社会招聘警务辅助人员58人考试参考试题及答案解析
- 金融文本数据深度挖掘与分析-洞察及研究
- 2025江苏宿迁泗阳县部分县属国有企业招聘劳务派遣人员考试参考试题及答案解析
- 山东省名校考试联盟2026届高三上学期10月阶段性检测物理试卷(含答案)
- 2026年高考语文备考之古诗文图文情境默写题仿真专练(含答案)
- 餐饮业员工岗位职责及考核标准手册
- 急性心梗诊疗(2025指南)解读课件
- 中国文化概论完整笔记张岱年
 
            
评论
0/150
提交评论