《软件工程导论(第五版)课后习题答案.pdf》由会员分享,可在线阅读,更多相关《软件工程导论(第五版)课后习题答案.pdf(43页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
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=4 0 8 0 e 0.2 8(Y-1 9 6 0)存储器的价格按下面公式描述的趋势逐年下降:P 1=O.3 X 0.7 2 Y T 9 7 4(美分/位)如果计算机字长为1 6 位,则存储器价格下降的趋势为:P 2=0.0 4 8 X 0.7 2 Y T 9 7 4(美元/字)在上列公式中Y 代表年份,M是存储容量(字数),P 1 和 P 2 代表价格。基于上述假设可以比较计算机硬件和软件成本的变化趋势
5、。要求计算:(1)在 1 9 8 5 年对计算机存储容量的需求估计是多少?如果字长为1 6 位,这个存储器的价格是多少?(2)假设在1 9 8 5 年一名程序员每天可开发出1 0 条指令,程序员的平均工资是每月4 0 0 0 美元。如果一条指令为一个字长,计算使存储器装满程序所需用的成本。(3)假设在1 9 9 5 年存储器字长为3 2 位,一名程序员每天可开发出3 0 条指令,程序员的月平均工资为6 0 0 0 美元,重复(1)、(2)题。(1)在1985年对计算机存储容量的需求,估计是M=4 0 8 0 e 0 2 8(i 9 8 5 i 9 6 o)=4 0 8 0 e7=4,4 7 4
6、,2 6 3(字)如果字长为16位,则这个存储器的价格是 _P=0.0 4 8 x 0.7 21 9 8 5-1 9 7 4 x 4 4 7 4 2 6 3 =5,7 8 9(美元)(2)如果一条指令的长度为一个字,则使存储器装满程序共需4474263条指令。在1985年一名程序员每天可开发出10条指令,如果每月有20个工作日,则每人每月可开发出10X20条指令。为了开发出4474263条指令以装满存储器,需要的工作量是:4 4 7 4 2 6 3 皿“口、-P 2 2,3 7 1(人月)2 0 0 程序员的月平均工资是4000美元,开发出4474263条指令的成本是 22371 x4000=
7、89,484,000(美元)(3)在1995年对存储容量的需求估计为:M 二 4080e0 28(199X960)=73,577,679(字)=4080e9 8 如果字长为32位,则这个存储器的价格是:_尸=0.003x32x0.721995T974 x73577679=7,127(美 元)如果一条指令为一个字长,则为使存储器装满程序共需73,577,679条指令。在1995年一名程序员每天可开发出30条指令,每月可开发出600条指令,为了开发出可装满整个存储器的程序,需要的工作量为73577679 口、-x 122,629(人月)600 开发上述程序的成本为:122629x60002 735
8、,776,790(美元)1-6什么是软件过程?它与软件工程方法学有何关系?软件过程是为了开发出高质量的软件产品所需完成的一系列任务的框架,它规定了完成各项任务的工作步骤。软件过程定义了运用技术方法的顺序、应该交付的文档资料、为保证软件质量和协调软件变化必须采取的管理措施,以及标志完成了相应开发活动的里程碑。软件过程是软件工程方法学的3个重要组成部分之一。4 .构成软件项目的最终产品:应用程序、系统程序、面向用户的文档资料和面向开发者的文档资料。5 .什么是软件生存周期?软件生存周期是指从软件定义、开发、使用、维护到淘汰的全过程。6 .软件生存周期为什么划分成阶段?(1)任何一个阶段的具体任务不
9、仅独立,而且简单,便于不同人员分工协作,从而降低整个软件开发工作的困难程度。(2)可以降低每个阶段任务的复杂程度,简化不同阶段的联系,有利于工程的组织管理,也便于采用良好的技术方法。(3)使软件开发的全过程以一种有条不紊的方式进行,保证软件的质量,特别是提高了软件的可维护性。7 .应该怎样来划分阶段?(1)每一个阶段的任务尽可能独立;(2)同一阶段内的任务性质尽可能相同;(3)每一个阶段任务的开始和结束有严格的标准。8.软件开发模型有儿种?它们的开发方法有可特点?软件开发模型有瀑布型、渐增型和变换型。瀑布型开发方法是按照软件生存周期的划分依次实施,每一个阶段有明确规定的任务。它的特点:(1)各
10、个阶段的顺序性和依赖性;(2)划分逻辑设计与物理设计,尽可能推迟程序的物理实现;(3)每个阶段必须完成规定的文档,对其中问题通过复审及早发现,及早解决。渐增型开发方法及特点:(1)从部分需求出发,先建立一个不完全的系统,通过测试运行该系统取得经验和信息反馈,加深对软件需求的理解,进一步使系统扩充和完善。如此反复,直至软件人员和用户对所设计完成的软件系统满意为止。(2)在渐增型开发下的软件是随软件开发的过程而逐渐形成的。(3)渐增型开发方法适合于知识型软件的开发,设计系统时对用户需求的认识开始不是很清楚的,需要在开发过程中不断认识、不断获得新的知识去丰富和完善系统。多数研究性质的试验软件,一般采
11、用此方法。变换型开发方法及特点:(1)从软件需求的形式化规格说明出发,经过一系列的程序变换,得到最终的程序系统。(2)该方法必须有严格的数学理论和形式化技术的支持。9.什么是软件工程?软件工程是指导计算机软件开发和维护的工程学科。(1)它采用工程的概念、原理、技术和方法来开发和维护软件;(2)它将管理技术与当前经过时间考验的而证明是正确的技术方法结合起来;(3)它强调使用生存周期方法学和结构分析和结构技术;(4)经过人们长期的努力和探索,围绕着实现软件优质高产这个目标,从技术到管理两个方面做了大量的努力,逐渐形成了“软件工程学”这一新的学科。1 0.什么是软件工程环境:方法与工具的结合,加上配
12、套的软、硬件支持称为软件工程环境。它能支持开发者按照软件工程的方法,全面完成生存周期中的各项任务。第 二 章 可行性研究习题答案L 问题定义的任务和主要工作?问题定义的任务:将用户提出的要求具体化、定量化;确定研制系统的范围,明确研制的边界。问题定义阶段的工作:(1)通过调查研究,了解系统需求;(2)确定系统的功能需求、性能需求、可靠性需求、安全及保密性、资源、开发费用及开发进度等的需求;(3)问题定义阶段的产品一系统目标与范围说明书。2.可行性研究目的?确定在问题定义中所提出的问题是否值得去解,在限制条件下,问题能否解决。3.可行性研究的任务?(1)进一步分析和澄清问题的定义,在澄清问题的基
13、础上,导出系统的逻辑模型;(2)从系统逻辑模型中,选择问题的若干种主要解法,研究每一种解法的可行性,为以后的行动提出建议;(3)如果问题没有可行的解,建议停止系统开发;如果问题有可行的解,应该推荐一个较好的解决方案,并为工程制定一个初步的计划。4.可行性研究包括哪儿方面的内容?(1)技术可行性:现有技术能否实现本系统,现有技术人员能否胜任,开发系统的资源能否满足;(2)经济可行性:经济效益是否超出开发成本;(3)操作可行性:系统操作在用户内部行得通吗?(4)法律可行性:新系统开发是否会侵犯他人、集体或国家利益,是否违反国家法律。5.可行性研究的步骤?(1)复查系统的规模和目标;(2)研究目前正
14、在使用的系统,总结现有系统的优劣,提出新系统的雏形;(3)导出新系统的高层逻辑模型;(4)推荐建议方案;(5)推荐行动方针;(6)书写计划任务书(可行性报告);(7)提交审查。6.可行性研究报告的主要内容?可行性分析的结果是可行性研究报告,内容包括:(1)系统概述:说明开发的系统名称,提出单位和开发单位。(2)可行性研究的前提:系统目标;要求;约束和限制;可行性研究的基本准则等。(3)对现有系统的分析:处理流程,图示说明现有系统的处理流程和数据流程;现有系统存在的问题。(4)系统需求:主要功能;主要性能及其要求;操作要求;信息要求;限制性要求。(5)建议系统:系统目标;处理流程;系统结构,功能
15、,性能;系统技术可行性;投资和效益分析;操作可行性;法律可行性。(6)其它可选方案:与国内外同类型方案的比较;提 出 一 两个可行性方案供论证和探讨。(7)制定下一阶段的预算。(8)结论性意见:由用户方、设计方和投资方共同签署意见。2-4目前住院病人主要由护士护理,这样做不仅需要大量护士,而且由于不能随时观察危重病人的病情变化,还会延误抢救时机。某医院打算开发一个以计算机为中心的患者监护系统,请分层次地画出描述本系统功能的数据流图。医院对患者8监护系统的基本要求是随时接收每个病人的生理信号(脉搏、体温、血压、心电图等),定时记录病人情况以形成患者日志,当某个病人的生理信号超出医生规定的安全范围
16、时向值班护士发出警告信息,此外,护士在需要时还可以要求系统印出某个指定病人的病情报告。从问题陈述可知,本系统数据源点是“病人”和“护士”,他们分别提供生理信号和要求病情报告的信息。进一步分析问题陈述,从系统应该“定时记录病人情况以形成患者日志”这项要求可以想到,还应该有一个提供日期和时间信息的“时钟”作为数据源点。从问题陈述容易看出,本系统的数据终点是接收警告信息和病情报告的护士。系统对病人生理信号的处理功能主要是“接收信号”、“分析信号”和“产生警告信息”。此外,系统还应该具有“定时取样生理信号”、“更新日志”和“产生病情报告”的功能。为了分析病人生理信号是否超出了医生规定的安全范围,应该存
17、储“患者安全范围”信息。此外,定时记录病人生理信号所形成的“患者日志”,显然也是一个数据存储。F5安 全 范 围 一 D2患者安全范围2-5 北京某高校可用的电话号码有以下几类:校内电话号码由4位数字组成,第 1位数字不是0;校外电话又分为本市电话和外地电话两类,拨校外电话需先拨0,若是本市电话则再接着拨8 位数字(第 1 位不是0),若是外地电话则拨3 位区码再拨8位电话号码(第 1 位不是0)。请用定义数据字典的方法,定义上一述的电话号码。数据结构的描述符 号 含 义 举被定义为+与 xE.或 .I.或 -或 m .n 重复 x(.)基本数据元素=a+bx=a,b ,x=a I b=a,x
18、=3 a 8可选 x=(a)x=a例连结符x=1.9电话号码=校内电话号码I 校外电话号码校内电话号码=非零数字+3位数字 后面继续定义校外电话号码=本市号码I 外地号码本市号码=数字零+8 位数字外地号码=数字零+3 位数字+8 位数字非零数字=1|2|3 5 7|8 9 数字零=03 位数字=3 数字 3 /3 至 3个数字8位数字=非零数字+7 位数字7 位数字=7 数字 7数字=0|1|2|3|4|5|6 1 7 8 9 第 三 章 需 求 分 析 习 题 答 案1 .需求分析的描述工具有哪些?有数据流图、数据字典、判定表、判定树、结构化自然语言、层次方框图、W ar n i e r图
19、、I P O 图和需求描述语言等。2 .需求分析的基本任务是什么?准确定义未来系统的目标,确定为了满足用户的需要系统必须做什么。3 .怎样建立目标系统的逻辑模型?要经过哪些步骤?建立目标系统的逻辑模型的过程也就是数据流图的分解过程。它的导出过程如图:1,分祈追踪数据流图有补充修正无补充修正用户复查继续分解不分解4.什么是结构化分析?它的结构化体现在哪里?结构化分析:使用数据流程图、数据字典、结构化英语、判定表和判定树等工具,来建立一种新的、称为结构化说明书的目标文档-需求规格说明书。结构化体现在将软件系统抽象为系列的逻辑加工单元,各单元之间以数据流发生关联。5.软件需求规格说明书由哪些部分组成
20、?组成包括:(1)引言:编写目的、背景说明、术语定义及参考资料等。(2)概述主要功能、约束条件或特殊需求。(3)数据流图与数据字典。(4)用户接口、硬件接口及软件接口。(5)性能需求、属性等。(6)其它需求,如数据库、操作及故障处理等。6.为什么数据流图要分层?画分层的DFD要遵循哪些原则?分层的目的:便于逐步细化、结构清晰。画分层的DFD要遵循哪些原则:(1)父图与子图之间数据要平衡。(2)分解的深度和层次达到使加工足够简单、易于理解的基本加工为止。(3)区分局部文件和局部外部项(局限于数据流中某一层或某几层的文件和外部项)。(4)不要把控制流作为数据流。(5)忽略琐碎的枝节。(6)每个数据
21、流要有一个合适的名字,尽量使用现实系统中有具体意义的名字。7.系统流程图与数据流程图有什么区别?系统流程图描述系统物理模型的工具,数据流程图描述系统逻辑模型的工具。系统流程图从系统功能的角度抽象的描述系统的各个部分及其相互之间信息流动的情况。数据流程图从数据传送和加工的角度抽象的描述信息在系统中的流动和数据处理的工作状况。8.数据字典包括哪些内容?它的作用是什么?数据字典是描述数据流图中数据的信息的集合。它对数据流图上每一个成分:数据项、文件(数据结构)、数据流、数据存储、加工和外部项等给以定义和说明;它主要由数据流描述、加工描述和文件描述三部分组成。对用户来讲,数据字典为他们提供了数据的明确
22、定义;对系统分析员来讲,数据字典帮助他们比较容易修改已建立的系统逻辑模型。9.描述加工逻辑的工具有哪些?有决策树(又称判定树)、决策表(又称判断表)和结构化语言等。3-3银行计算机储蓄系统的工作过程大致如下:储户填写的存款单或取款单由业务员键入系统,如果是存款则系统记录存款人姓名、住址(或电话号码)、身份证号码、存款类型、存款日期、到期日期、利率及密码(可选)等信息,并印出存单给储户;如果是取款而且存款时留有密码,则系统首先核对储户密码,若密码正确或存款时未留密码,则系统计算利息并印出利息清单给储户。请用数据流图描绘本系统的功能,并用实体-联系图描绘系统中的数据对象。F5存款信息F5存款信息D
23、1存款信息f P3 P47核京1 码 F6取款信息-计 第 u息卜F8储蓄利率3-6 复印机的工作过程大致如下:未接到复印命令时处于闲置状态,一旦接到复印命令则进入复印状态,完成一个复印命令规定的工作后又回到闲置状态,等待下一个复印命令;如果执行复印命令时发现没纸,则进入缺纸状态,发出警告,等待装纸,装满纸后进入闲置状态,准备接收复印命令;如果复印时发生卡纸故障,则进入卡纸状态,发出警告等待维修人员来排除故障,故障排除后回到闲置状态。请用状态转换图描绘复印机的行为。从问题陈述可知,复印机的状态主要有“闲置”、“复印”、“缺纸”和“卡纸”。引起状态转换的事件主要是“复印命令”、“完成复印命令”、
24、“发现缺纸”、“装满纸”、“发生卡纸故障”和“排除了卡纸故障”。第五章总体设计习题答案1.系统设计包括哪两个阶段?系统设计包括总体设计与详细设计两个阶段。2.总体设计的主要任务是什么?总体设计的主要任务是完成软件结构的设计,确定系统的模块及其模块之间的关系。3.什么是模块?模块具有哪几个特征?总体设计主要考虑什么特征?模块是数据说明、可执行语句等程序对象的集合,可以单独命名且可通过名字来访问。模块具有输入和输出(参数传递)、功能、内部数据结构(局部变量)和程序代码四个特性。概要设计主要考虑输入、输出(参数传递)和功能两个特性。4.什 么是模块化?模块设计的准则?模块化是按规定的原则将个大型软件
25、划分为一个个较小的、相对独立但又相关的模块。模块设计的准则:(1)改进软件结构,提高模块独立性:在对初步模块进行合并、分解和移动的分析、精化过程中力求提高模块的内聚,降低藕合。(2)模块大小要适中:大 约 5 0 行语句的代码,过大的模块应分解以提高理解性和可维护性;过小的模块,合并到上级模块中。(3)软件结构图的深度、宽度、扇入和扇出要适当。一般模块的调用个数不要超过5 个。(4)尽量降低模块接口的复杂程度;(5)设计单入口、单出口的模块。(6)模块的作用域应在控制域之内。5.变换型数据流由哪几部分组成?变换型结构由三部分组成:传入路径、变换(加工)中心和传出路径。6.变换分析设计的步骤?(
26、1)区分传入、传出和变换中心三部分,划分D F D 图的分界线;(2)完成第一级分解:建立初始S C 图的框架;(3)完成第二级分解:分解S C 图的各个分支;(4)对初始结构图按照设计准则进行精化与改进。7 .事务型数据流由哪儿部分组成?事务型结构由至少一条接受路径、一个事务中心与若干条动作路径组成。8 .事务分析设计的步骤?(1)在 D F D 图中确定事务中心、接收部分(包含全部接收路径)和发送部分(包含全部动作路径);(2)画出S C 图框架,把 D F D 图的三部分分?q u o t;映射”为事务控制模块,接收模块和动作发送模块.一般得到SC图的顶层和第一层(如果第一层简单可以并入
27、顶层);(3)分解和细化接收分支和动作分支,完成初始的S C 图;(4)对初始结构图按照设计准则进行精化与改进。9 .比较层次方框图与结构图是的异同?(1)层次方框图描绘数据的层次结构,结构图描绘的是软件结构。(2)二者都采用多层次矩形框树形结构。层次方框图的顶层矩形框代表完整的数据结构,下面各层矩形框依次代表上个框数据的子集;结构图 是在层次图的每一个方框内注明模块的名字或主要功能,方框之间的直线表示模块的调用关系,用带注解的箭头表示模块调用过程中传递的信息。10.欲开发一个银行的活期存取款业务的处理系统:储户将填好的存/取款单和存折交给银行工作人员,然后由系统作以下处理;(1)业务分类处理
28、:系统首先根据储户所填的存/取款单,确定本次业务的性质,并将存/取款单和存折交下一步处理;(2)存款处理:系统将存款单上的存款金额分别记录在存折和帐目文件中,并将现金存入现金库;最后将存折还给储户;(3)取款处理:系统将取款单上的取款金额分别记录在存折和帐目文件中,并从现金库提取现金;最后将现金和存折还给储户。绘制该系统的数据流图和软件结构图。顶层二层储户修改存折注:A一文件帐目及存折;B一现金帐软件结构图存取款业务系统退回存款处理 取款处理获得合理单据输入单据审核单据1存取单、存折3不合格单据5合格存折、取款单2合格单据4合格存折、存款单修改现金帐补 充 1:请为某仓库的管理设计一个ER 模
29、型。该仓库主要管理零件的订购和供应等事项。仓库向工程项目供应零件,并且根据需要向供应商订购零件本问题中共有三类实体,分别是“零件”、“工程项目”和“供应商”。一种零件可供应多个工程项目,一个工程项目需要使用多种零件,因此,零件与工程项目之间的联系“供应”,是多对多(M N )联系;类似地,零件与供应商之间的联系“订购”,也是多对多(M N )联系。实体类型“零件”的主要属性是:零件编号,零件名称,颜色,重量。实体类型“工程项目”的属性主要是:项目编号,项目名称,开工日期。实体类型“供应商”的属性主要有:供应商编号,供应商名称,地址。联系类型“供应”的属性是,向某工程项目供应的某种零件的数量。联
30、系类型“订购”的属性是,向某供应商订购的某种零件的数量。补充2:某火车售票系统的数据流程图如下所示日期查询结果按日期查询I录入员查询信息查询信息2接受查询分析查班次1-线路按班次查询5按线路查询查询结果6查询结果查询显示查询结果补充3、已知某定货系统的需求分析DFD图如下,请按SD方法的设计步骤画出结构图。订货单D1配件合格峥单不布格订货单D4暂存订货单D4暂存订货单D5销售历史D2顾客文件 D3配件库学合格订货看获取订货及库存信息定货系统配件库术 L-A 暂存订货单合格讨贷单 *配 件 库 存 暂 存 订 货 前合格订货巾审核定货单订 货 单 配 件 信 息订货单顾客信息订货中获 财货单/R
31、配件库存合格诃货中获取配件库存ZS处理顾客订货 输 出 喘 息合格订货中 销售信息账款信息v发货单/产生发货单产生应收款 产生销售历明细帐 史5-3用面向数据流的方法设计下列系统的软件结构(1)储 蓄 系 统2-2(2)机 票 预 定 系 统2-3为了方便旅客,某航空公司拟开发一个机票预定系统。旅行社把预定机票的旅客 信 息(姓 名、性 别、工作单位、身份证号码、旅行时间、旅 行 目 的 地 等)输 入 该系统,系统为旅客安排航 班,旅客在飞机起飞前一天凭取票通知和账单交款取票,系统核对无误即印出机票给顾客(2)患者监护系统2-4不能是两个分开的子系统,是相同的前台单个处理账 单 取 票 通
32、知Y Y _账单 取票通知机票可以是两个子系统,预定和取票是不同的处理方式(后台批量和前台单个)E2病人F6日志,时间F4警告信息P3产生警告信息 0A=B+1I F A 1 0T H EN X=AEL S E Y=ZEND I FI F Y 0T H EN P R I NT GEL S E P R I NT KEND I FS T O P丫&)=结点 一弧数1)+1=1 7-1 1+1=7=判断结点+1=6 +1 =7=封闭的区域数充 1、某高校研究生招生系统的初选方法如下:总分3 0 0 (含)以上进入候选学生库,否则退档;数学分数不低于7 0 分,则进入三级备选库,否则进入四级备选库;在
33、三级备选库的基础上,如果专业课分数高于1 0 0 分,则进入一级备选库,否则进入二级备选库,请画出对应的判定树。它生初这70华一破库如多专业W100-二破区6 B)theni f(A V B=thenif(X Y)thenA:=B;B:=Y;else if(X Y)thenelseB:=Y;A:=X;elseendif;A:=X;elseendif;A=:B;endif;4 0:WH I L E C l D Oexitl:=false;exit2:=false;B E G I NI F C 2 TH E N G O TO 2 0?WH I L E C l A N D (N O T exitl)
34、A N D (N O T exit2)B E G I NI F C 3 TH E N G O TO 3 0;I F C 2 TH E N exitl:=true;E N D;2 0:code for C 2 exit)I F C 3 TH E N exit2:=true?E N D ;G O TO 4 0;3 0:code for C 3 exitI F (exitl)TH E N G O TO 2 0;I F (exit2)TH E N G O TO 3 0;4 0:2 0:code for C 2 exitG O TO 4 0?3 0:code for C 3 exit)7-4(3)、设计
35、下列伪码程序的语句覆盖和路径覆盖测试用例:STA RTI N PUT(A,B,C)/判定表达式1I F A 5 TH E NX=1 0E L SEX=1E N D I F判定表达式2I F B 1 0 TH E NY=2 0E L SEY=2E N D I F/判定表达式3I F 0 1 5 TH E NZ=3 0E L SEZ=3E N D I FPRI N T(X,Y,Z)STO P语句覆盖的测试用例序号判定输入出123ABCXYZ1FFF1111232TTT20 4060 10 20 30路径覆盖的测试用例序号判定输入涯期的输出123ABCXYZ1FFF1111232FFT1160123
36、03FTF140112034FTT14060120305TFF201110236TFT20160102307TTF20401102038TTT204060102030第七章习题参考答案一.回答问题1.软件测试的基本任务?软件测试是按照特定的规则,发现软件错误的过程;好的测试方案是尽可能发现迄今尚未发现错误的测试:成功的测试方案是发现迄今尚未发现错误的测试;2.测试与调试的主要区别?(1)(1)测试从一个侧面证明程序员的失败;调试证明程序员的正确;(2)(2)测试从已知条件开始,使用预先定义的程序,且有预知的结果,不可预见的仅是程序是否通过测试;调试从不可知内部条件开始,除统计性调试外,结果是不
37、可预见的;(3)(3)测试有计划并且要进行测试设计;调试不受时间约束;(4)(4)测试是发现错误、改正错误、重新测试的过程;调试是一个推理的过程;(5)(5)测试执行是有规程的;调试执行要求程序员进行必要的推理;(6)(6)测试由独立的测试组在不了解软件设计的件下完成;调试由了解详细设计的程序员完成;(7)(7)大多数测试的执行和设计可由工具支持;调试用的工具主要是调试器。3.人工复审的方式和作用?人工复审的方式:代码会审、走查和排练和办公桌检查;人工复审的作用:检查程序的静态错误。4.什么是黑盒测试?黑盒测试主要采用的技术有哪些?黑盒测试也称为功能测试,它着眼于程序的外部特征,而不考虑程序的
38、内部逻辑结构。测试者把被测程序看成一个黑盒,不用关心程序的内部结构。黑盒测试是在程序接口处进行测试,它只检查程序功能是否能按照规格说明书的规定正常使用,程序是否能适当地接收输入数据产生正确的输出信息,并且保持外部信息(如数据库或文件)的完整性。黑盒测试主要采用的技术有:等价分类法、边沿值分析法、错误推测法和因果图等技术。5.什么是白盒测试?白盒测试主要采用的技术有哪些?测试者了解被测程序的内部结构和处理过程,对程序的所有逻辑路径进行测试,在不同点检查程序状态,确定实际状态与预期状态是否一致。白盒测试主要采用的技术有:路径测试技术和事务处理流程技术,对包含有大量逻辑判断或条件组合的程序采用基于逻
39、辑的测试技术。6.路径测试技术中儿种主要覆盖的含义?举例说明?语句覆盖:至少执行程序中所有语句一次。判定覆盖:使被测程序中的每一个分支至少执行一次。故也称为分支覆盖。条件覆盖:执行所有可能的穿过程序的控制路流程。条件组合测试:设计足够的测试用例,使每个判定中的所有可能条件取值组合至少执行一次。(例略)7.等价分类法的测试技术采用的一般方法?举例说明?(1)(1)为每个等价类编号;(2)(2)设计一个新的测试方案,以尽可能多的覆盖尚未被覆盖的有效等价类,重复这一步骤,直到所有有效等价类被覆盖为止。(3)(3)设计一个新的测试方案,使它覆盖一个尚未被覆盖的无效等价类,重复这一步骤,直到所有无效等价
40、类被覆盖为止。(例略)8.软件测试的一般步骤?单元测试、子系统测试、系统测试、验收测试、平行测试。9.比较集成试的两种方式的优劣?非渐增式测试方式:分别测试模块,再把所有模块按设计要求放在一起组成所要的程序。该方法编写测试软件工作量大,模块间的接口错误发现得晚,错误定位较难诊断,总体测试有的错误容易漏掉,测试时间相对较少,可以并行测试所有模块,能充分利用人力,加快工程进度。渐增式测试方式:把下一个要测试的模块,同己经测试好的那些模块结合起来进行测试。t777XI/012345z(/(/(Xz(/(该方法利用已测试过的模块作测试软件,开销小,较早发现模块间的接口错误,错误定位往往和最近入的模块相
41、关,对己测试好的模块可在新加入模块的条件下受到新的检验,测试更彻底,需要较多的测试时间,不能并行测试。总的来说,渐增式测试方法比较好。测试的策略?(1)在任何情况下都应使用边界值分析的方法。(2)必要时用等价类划分法补充测试方案。(3)必要时再用错误推测法补充测试方案。(4)对照程序逻辑,检查已设计出的测试方案。(5)根据对程序可靠性的要求采用不同的逻辑覆盖标准,再补充一些测试方案。二.某电力公司有A、B、C、D 共四类收费标准,并规定,居民用电每月2 0 0 度以下按A类收费,2 0 0 度以上按B类收费。动力电以每月1 万度为分界,非高峰用电不足1 万度按B类收费,达到或超过1 万度按C
42、类收费。高峰用电不足1 万度按C 类收费,达到或超过1万度按I)类收费。试用基于逻辑的测试方法为它设计足够的测试用例实现条件组合的完全覆概。规则号123456居民用电2 0 0 度以下Y2 0 0 度以上Y动力用电非高峰1 万度以下Y1 万度以上Y高峰1 万度以下Y1 万度以上Y收费标准A类B类C类D类测试用例用电类型输入数据预期结果居民用电9 0 度/月A1 1 0 度/月B动力用电非高峰8 0 0 0 度/月B1 2 0 0 0 度/月C高峰9 0 0 0 度/月C1 1 0 0 0 度/月D三.如图显示某程序的逻辑结构。试为它设计足够的测试用例,分别实现对程序的判定覆概、条件覆概和条件组
43、合覆概。设计测试方案覆盖种类需满足的条件测试数据期望结果判定覆盖A l,B=0A=2,B=0执行s iA l,B*0 或A 4 1,B=0 或A 1B=0A=2,B=0执行S iA l,B=0A=2,B=0执行S IA 1,B MA=2,B=1执行S 2A l,B=0A=1,B=O执行S 2A l,B 0A=l,B=1执行$2四.某城市电话号码由三部分组成。它们的名称和内容分别是:地区码:空白或三位数字;前 缀:非 0 或 1 的三位数字;后 缀:4 位数字。假定被测程序能接受-一切符合上述规定的电话号码,拒绝所有不符合规定的电话号码。根据该程序的规格说明,作等价类的划分,并设计测试方案。1.
44、划分等价类输入条件有效等价类无效等价类地区码1 .空白;2 .三位数;1.1.有非数字字符;2.少于三位数字;3.多于三位数字。前 缀3.从 2 0 0 到 9 9 9 之间的三位4 .有非数字字符;5.起始位为,(T;6 .起始位为T;7.少于三位数字;8.多于三位数字。后 缀4.四位数字。9.有非数字字符;1 0.少于四位数字;1 1.多于四位数字。设计测试方案方案内容输 入预期输出地区码前缀后缀1空白2 0 0 9 9 9 之间的三位数字四位数字()2 7 6-2 3 4 5有效2三位数字四位数字(6 3 5)80 5-9 3 2 1有效3有非数字字符(2 0 A)7 2 3-4 5 6
45、 7无效4少于三位数字(3 3 )2 3 4-5 6 7 8无效5多于三位数字(5 5 5 5)3 4 5-6 7 89无效6有非数字字符(3 4 5)5 A 2-3 4 5 6无效7起始位为O(3 4 5)0 1 2-3 4 5 6无效8起始位为 1(3 4 5)1 3 2-3 4 5 6无效9少于三位数字(3 4 5)9 2-3 4 5 6无效1 0多于三位数字(3 4 5)4 5 6 2-3 4 5 6无效1 1有非数字字符(3 4 5)3 4 2-3 A 5 6无效1 2少于四位数字(3 4 5)3 4 2-3 5 6无效1 3多于四位数字(3 4 5)5 6 2-3 4 5 6 7无
46、效第 八 章 软 件 维 护 习 题 答 案1.为什么说软件的维护是不可避免的?因为软件的开发过程中,一般很难检测到所有的错误,其次软件在应用过程中需要随用户新的要求或运行环境的变化而进行软件的修改或完成功能的增删等,为了提高软件的应用水平和使用寿命,软件的维护是不可避免的。2.软件的维护一般分为哪儿类?改正性维护:满足用户对已开发产品的性能与运行环境不断提高的要求,进而达到延长软件寿命的目的。适应性维护:对程序使用期间发现的程序错误进行诊断和改正的过程,配合变化了的环境进行修改软件的活动;完善性维护:满足用户在使用过程中提出增加新的功能或修改已有功能的建议而进行的工作;预防性维护:为了改善未
47、来的可维护性或可靠性而修改软件的工作。3.影响软件维护的因素有哪些?开发方法:采用模块化详细设计文档有助于理解软件的结构、界面功能和内部流程;开发过程中严格而科学的管理规划及清晰可靠的文档资料对发生错误后的理解与纠错是至关重要的;开发过程中模块的独立程度越高,对软件修改越容易,对软件的改进和移植越方便。开发条件:软件开发及维护人员的水平决定了软件开发的质量和维护的效率;开发过程中使用标准的程序设计语言和标准的操作系统接口,可以大大提高软件的可维护性;在测试过程中用例的有效性,可极大地减少软件存在的错误;其次使用规范化的文档资料可为维护提供更好的依据。4.软件维护困难主要表现在什么方面?(1)一
48、般来讲,维护人员对开发人员写的程序及文档,理解都比较困难,对维护工作不会喜欢;(2)维护持续时间都很长,在开发人员不在现场的轻快下,维护软件通常是很困难的;(3)绝大多数软件在设计时对将来的软件修改都没有考虑或考虑不多,尤其未能在设计中强调并认真解决好模块的独立性,使软件的修改既困难乂易发生差错。5.决定软件可维护性的因素?(1)软件的可理解性、可测试性、可修改性;(2)文档描述符合要求、用户文档简洁明确、系统文档完整并且标准。6.软件价格应该计入维护成本吗?为什么?在软件的生命周期中,软件维护的工作量非常大,不同应用领域的维护成本差别也很大。一般大型软件的维护成本远远高于开发成本若干倍。因此
49、软件价格中应该计入维护成本。7.对前面各章中分析的各应用系统,提出改进和扩充功能的要求?(1)教材销售采购系统;(2)图书管理系统;(3)房产管理系统。(略)第 九 章 软 件 工 程 管 理 习 题 答 案1.软件工程管理的内容?(1)费用管理:对软件开发进行成本核算,使软件生产按照商品生产的规律办事。包括:以简单、科学方法估算软件开发费用,作为签定开发合同的根据;管理开发费用的有效使用,即用经济手段来保证产品如期按质完成。(2)质量管理:按项目的质量保证计划,确保各个开发阶段的开发和维护工作全部按软件工程的规范进行,保证软件产品的质量。(3)配置管理:通过对于程序、文档和数据的各种版本所进
50、行的管理,保证资料的完整性与一致性。(4)项目管理:制 定 项目实施计划,按照计划的内容组织和实施软件的工程化生产。最终目标是以合理的费用和进度,圆满完成计划所规定的软件项目。2.软件项目有哪些特点?(1)软件项目与其他任何产业项目不同,它是算法、思想、概念、组织、流程、效率、优化等的融合体;(2)开发软件项目产品,在多数情况下,用户给不出明确的想法和要求。(3)在开发过程中,程序及其相关的文档资料常常需要修改,在修改过程中又可能带来新的问题,且这些问题要在很久以后才会发现。(4)在研制开发过程中,文档资料是不可缺少的,但工作量又是巨大的,往往也是人们不愿去作的。(5)参加软件项目的工作人员,