还剩32页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
《软件工程导论》课后习题答案第一章软件工程概论
1.什么是软件危机?它们有哪些典型表现?为什么会出现软件危机? “软件危机”是指计算机软件的“开发”和“维护”过程中所遇到的一系列“严重问题”这些问题决不仅仅是不能正常运行的软件才具有的,实际上,几乎“所有软件”都不同程度地存在这些问题“软件危机”包含两方面的问题
(1)如何开发软件,以满足对软件日益增长的需求;
(2)如何维护数量不断膨胀的已有软件它们有以下表现
(1)对软件开发成本和进度的估计常常很不准确;
(2)用户对“已完成的”软件系统不满意的现象经常发生;
(3)软件产品的质量往往靠不住;
(4)软件常常是不可维护的;
(5)软件通常没有适当的文档资料;
(6)软件成本在计算机系统总成本中所占的比例逐年上升;
(7)软件开发生产率提高的速度,远远跟不上计算机应用普及深入的趋势出现软件危机的原因
(1)开发人员与客户认识之间的矛盾
(2)开发人员能力与开发目标之间的矛盾
(3)预估与实际工作量之间的矛盾
(4)客户认识的提高与软件维护之间的矛盾
(5)遗产系统与实施软件之间的矛盾
2.假设自己是一家软件公司的总工程师,当把图
1.1给手下的软件工程师们观看,告诉他们及时发现并改正错误的重要性时,有人不同意这个观点,认为要求在错误进入软件之前就清楚它们是不现实的,并举例说“如果一个故障是编码错误造成的,那么,一个人怎么能在设计阶段清除它呢?”应该怎么反驳他?答在软件开发的不同阶段进行修改付出的代价是很不相同的,在早期引入变动,涉及的面较少,因而代价也比较低;在开发的中期,软件配置的许多成分已经完成,引入一个变动要对所有已完成的配置成分都做相应的修改,不仅工作量大,而且逻辑上也更复杂,因此付出的代价剧增;在软件“已经完成”是在引入变动,当然付出的代价更高一个故障是代码错误造成的,有时这种错误是不可避免的,但要修改的成本是很小的,因为这不是整体构架的错误
3.什么是软件工程?它有哪些本质特征?怎么用软件工程消除软件危机?软件工程是知道计算机软件开发和维护的一门工程学科采用工程的概念、原理、技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够得到的最好技术方法结合起来,以经济地开发出高质量的软件并有效地维护它,这就是软件工程本质特征
(1)软件工程关注于大型软件的构造
(2)软件工程的中心课题是控制复杂性
(3)软件经常变化
(4)开发软件的效率非常重要
(5)和谐地合作是开发软件的关键
(6)软件必须有效支持它的用户
(7)在软件工程领域通常由一种文化背景的人替代具有另一种文化背景的人创造产品消除软件危机的原理
(1)用分阶段的生命周期计划严格管理
(2)坚持进行阶段评审
(3)实行严格的产品控制
(4)采用现代程序设计技术
(5)结果应能清楚地审查
(6)开发小组的人员应该少而精
(7)承认不断改进软件工程实践的必要性5.根据历史数据可以做出如下的假设对计算机存储容量的需求大致按下面公式描述的趋势逐年增加M=4080e
0.28Y-1960存储器的价格按下面公式描述的趋势逐年下降P1=
0.3×
0.72Y-1974美分/位如果计算机字长为16位,则存储器价格下降的趋势为P2=
0.048×
0.72Y-1974美元/字在上列公式中Y代表年份,M是存储容量字数,P1和P2代表价格基于上述假设可以比较计算机硬件和软件成本的变化趋势要求计算1在1985年对计算机存储容量的需求估计是多少如果字长为16位,这个存储器的价格是多少2假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元如果一条指令为一个字长,计算使存储器装满程序所需用的成本3假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复
1、2题1-6什么是软件过程它与软件工程方法学有何关系软件过程是为了开发出高质量的软件产品所需完成的一系列任务的框架,它规定了完成各项任务的工作步骤软件过程定义了运用技术方法的顺序、应该交付的文档资料、为保证软件质量和协调软件变化必须采取的管理措施,以及标志完成了相应开发活动的里程碑软件过程是软件工程方法学的3个重要组成部分之一
7.什么是软件生命周期模型?试比较瀑布模型、快速模型、增量模型和螺旋模型的优缺点,说明每种模型的适用范围通俗的说,简洁地描述软件过程的模型叫做软件生命周期模型,生命周期模型规定了把生命周期花费成哪些阶段及各个阶段执行的顺序模型名称比较特点适用范围方法学角度应用角度面向结构面型对象外部项目内部产品瀑布模型基础模型、广泛使用、标准模式是是快速模型基本需求、原形系统、可行演练是是增量模型需求分解、增量构件、并行设计面向对象是是螺旋模型原形系统、风险分析、大规模附带风险分析的快速原形模型是是
8.为什么说喷泉模型较好地体现了面向对象软件开发过程无缝和迭代的特性?由于在整个开发过程中都使用统一的软件概念“对象”,所有其他概念(例如功能、关系、事件等)都是围绕对象组成的,目的是保证分析工作中得到的信息不会丢失或改变,因此,对生命周期各个阶段的区分自然也就不重要了,不明显了分析阶段的得到的对象模型也适用于设计阶段和实现阶段由于各阶段都使用统一的概念和表示符号,因此,整个开发过程都是吻合一致的,或者说是“无缝”连接的,这自然也就很容易实现各个开发步骤的多次反复迭代,达到认识的逐步深化所以说喷泉模型较好的体现了面向对象软件开发过程无缝和迭代的特性
4.构成软件项目的最终产品 应用程序、系统程序、面向用户的文档资料和面向开发者的文档资料5.什么是软件生存周期? 软件生存周期是指从软件定义、开发、使用、维护到淘汰的全过程6.软件生存周期为什么划分成阶段? 1任何一个阶段的具体任务不仅独立,而且简单,便于不同人员分工协作,从而降低整个软件开发工作的困难程度 2可以降低每个阶段任务的复杂程度,简化不同阶段的联系,有利于工程的组织管理,也便于采用良好的技术方法 3使软件开发的全过程以一种有条不紊的方式进行,保证软件的质量,特别是提高了软件的可维护性7.应该怎样来划分阶段? 1每一个阶段的任务尽可能独立; 2同一阶段内的任务性质尽可能相同; 3每一个阶段任务的开始和结束有严格的标准8.软件开发模型有几种?它们的开发方法有可特点? 软件开发模型有瀑布型、渐增型和变换型 瀑布型开发方法是按照软件生存周期的划分依次实施,每一个阶段有明确规定的任务它的特点 1各个阶段的顺序性和依赖性; 2划分逻辑设计与物理设计,尽可能推迟程序的物理实现; 3每个阶段必须完成规定的文档,对其中问题通过复审及早发现,及早解决 渐增型开发方法及特点: 1从部分需求出发,先建立一个不完全的系统,通过测试运行该系统取得经验和信息反馈,加深对软件需求的理解,进一步使系统扩充和完善如此反复,直至软件人员和用户对所设计完成的软件系统满意为止 2在渐增型开发下的软件是随软件开发的过程而逐渐形成的 3渐增型开发方法适合于知识型软件的开发,设计系统时对用户需求的认识开始不是很清楚的,需要在开发过程中不断认识、不断获得新的知识去丰富和完善系统多数研究性质的试验软件,一般采用此方法 变换型开发方法及特点: 1从软件需求的形式化规格说明出发,经过一系列的程序变换,得到最终的程序系统 2该方法必须有严格的数学理论和形式化技术的支持
9.什么是软件工程 软件工程是指导计算机软件开发和维护的工程学科 1它采用工程的概念、原理、技术和方法来开发和维护软件; 2它将管理技术与当前经过时间考验的而证明是正确的技术方法结合起来; 3它强调使用生存周期方法学和结构分析和结构技术; 4经过人们长期的努力和探索,围绕着实现软件优质高产这个目标从技术到管理两个方面做了大量的努力逐渐形成了软件工程学这一新的学科10.什么是软件工程环境:方法与工具的结合,加上配套的软、硬件支持称为软件工程环境它能支持开发者按照软件工程的方法全面完成生存周期中的各项任务第二章 可行性研究 习题答案
1.问题定义的任务和主要工作 问题定义的任务将用户提出的要求具体化、定量化;确定研制系统的范围,明确研制的边界 问题定义阶段的工作 1通过调查研究,了解系统需求; 2确定系统的功能需求、性能需求、可靠性需求、安全及保密性、资源、开发费用及开发进度等的需求; 3问题定义阶段的产品--系统目标与范围说明书
2.可行性研究目的 确定在问题定义中所提出的问题是否值得去解,在限制条件下,问题能否解决3.可行性研究的任务? 1进一步分析和澄清问题的定义,在澄清问题的基础上,导出系统的逻辑模型; 2从系统逻辑模型中,选择问题的若干种主要解法,研究每一种解法的可行性,为以后的行动提出建议; 3如果问题没有可行的解,建议停止系统开发;如果问题有可行的解,应该推荐一个较好的解决方案,并为工程制定一个初步的计划4.可行性研究包括哪几方面的内容? 1技术可行性现有技术能否实现本系统,现有技术人员能否胜任,开发系统的资源能否满足; 2经济可行性经济效益是否超出开发成本; 3操作可行性系统操作在用户内部行得通吗? 4法律可行性新系统开发是否会侵犯他人、集体或国家利益,是否违反国家法律5.可行性研究的步骤 1复查系统的规模和目标; 2研究目前正在使用的系统,总结现有系统的优劣,提出新系统的雏形; 3导出新系统的高层逻辑模型; 4推荐建议方案; 5推荐行动方针; 6书写计划任务书可行性报告; 7提交审查
6.可行性研究报告的主要内容? 可行性分析的结果是可行性研究报告内容包括 1系统概述说明开发的系统名称提出单位和开发单位 2可行性研究的前提:系统目标;要求;约束和限制;可行性研究的基本准则等 3对现有系统的分析:处理流程,图示说明现有系统的处理流程和数据流程;现有系统存在的问题 4系统需求:主要功能;主要性能及其要求;操作要求;信息要求;限制性要求 5建议系统:系统目标;处理流程;系统结构功能性能;系统技术可行性;投资和效益分析;操作可行性;法律可行性 6其它可选方案:与国内外同类型方案的比较;提出一两个可行性方案供论证和探讨 7制定下一阶段的预算 8结论性意见由用户方、设计方和投资方共同签署意见2-4目前住院病人主要由护士护理,这样做不仅需要大量护士,而且由于不能随时观察危重病人的病情变化,还会延误抢救时机某医院打算开发一个以计算机为中心的患者监护系统,请分层次地画出描述本系统功能的数据流图医院对患者7监护系统的基本要求是随时接收每个病人的生理信号脉搏、体温、血压、心电图等,定时记录病人情况以形成患者日志,当某个病人的生理信号超出医生规定的安全范围时向值班护士发出警告信息,此外,护士在需要时还可以要求系统印出某个指定病人的病情报告F1-要求报告F2-生理信号F3-日期、时间F4-警告信息F5-安全范围F6-日志P1-接收信号P2-分析信号P3-产生警告P4-定时取样生理信号P5-更新日志P6-产生病情报告D1-患者日志D2-患者安全范围E1-护士E2-病人E3-时钟第三章 需求分析 习题答案
1.需求分析的描述工具有哪些 有数据流图、数据字典、判定表、判定树、结构化自然语言、层次方框图、Warnier图、IPO图和需求描述语言等
2.需求分析的基本任务是什么 准确定义未来系统的目标,确定为了满足用户的需要系统必须做什么
3.怎样建立目标系统的逻辑模型要经过哪些步骤建立目标系统的逻辑模型的过程也就是数据流图的分解过程它的导出过程如图
4.什么是结构化分析它的结构化体现在哪里 结构化分析:使用数据流程图、数据字典、结构化英语、判定表和判定树等工具,来建立一种新的、称为结构化说明书的目标文档-需求规格说明书 结构化体现在将软件系统抽象为一系列的逻辑加工单元各单元之间以数据流发生关联
5.软件需求规格说明书由哪些部分组成 组成包括 1引言编写目的、背景说明、术语定义及参考资料等 2概述主要功能、约束条件或特殊需求 3数据流图与数据字典 4用户接口、硬件接口及软件接口 5性能需求、属性等 6其它需求,如数据库、操作及故障处理等
6.为什么数据流图要分层画分层的DFD要遵循哪些原则 分层的目的便于逐步细化、结构清晰 画分层的DFD要遵循哪些原则 1父图与子图之间数据要平衡 2分解的深度和层次达到使加工足够简单、易于理解的基本加工为止 3区分局部文件和局部外部项局限于数据流中某一层或某几层的文件和外部项 4不要把控制流作为数据流 5忽略琐碎的枝节 6每个数据流要有一个合适的名字,尽量使用现实系统中有具体意义的名字
7.系统流程图与数据流程图有什么区别 系统流程图描述系统物理模型的工具,数据流程图描述系统逻辑模型的工具 系统流程图从系统功能的角度抽象的描述系统的各个部分及其相互之间信息流动的情况 数据流程图从数据传送和加工的角度抽象的描述信息在系统中的流动和数据处理的工作状况
8.数据字典包括哪些内容它的作用是什么? 数据字典是描述数据流图中数据的信息的集合它对数据流图上每一个成分数据项、文件数据结构、数据流、数据存储、加工和外部项等给以定义和说明;它主要由数据流描述、加工描述和文件描述三部分组成对用户来讲数据字典为他们提供了数据的明确定义;对系统分析员来讲数据字典帮助他们比较容易修改已建立的系统逻辑模型
9.描述加工逻辑的工具有哪些 有决策树又称判定树、决策表又称判断表和结构化语言等
10.某单位拟开发一个计算机房产管理系统,要求系统具有分房、调房、退房和查询统计等功能房产科将用户申请表输入系统后,系统首先检查申请表的合法性,对不合法的申请表,系统拒绝接收;对合法的申请表根据类型分别进行处理 1如果是分房申请,则根据申请者的情况年龄、工龄、职称、职务、家庭人口等计算其分数,当分数高于阀值分数时,按分数高低将申请单插到分房队列的适当位置在进行分房时,从空房文件中读出空房信息,如房号、面积、等级、单位面积房租等,把好房优先分给排在分房队列前面的符合该等级房条件的申请者;从空房文件中删掉这个房号的信息,并从分房队列中删掉该申请单,再把此房号的信息和住户信息一起写到住房文件中,输出住房分配单给住户,同时计算房租,并将算出的房租写到房租文件中 2如果是退房申请,则从住房文件和房租文件中删除有关信息,再把此房号的信息写到空房文件中 3如果是调房申请,则根据申请者的情况确定其住房等级,然后在空房文件中查找属于该等级的空房,退掉原住房,再进行与分房类似的处理 4住户可以向系统查询目前分房的阀值分数,居住某类房屋的条件,某房号的单位面积及房租等信息房产科可以要求系统打印住房情况的统计表,或更改某类房屋的居住条件、单位面积和房租等 用数据流图描绘该系统的功能需求;在数据字典中给出主要的数据流、文件和加工说明参考第四章
4.5应用举例教案之二分析第四章总体设计 习题答案
1.系统设计包括哪两个阶段 系统设计包括总体设计与详细设计两个阶段
2.总体设计的主要任务是什么? 总体设计的主要任务是完成软件结构的设计确定系统的模块及其模块之间的关系
3.什么是模块?模块具有哪几个特征?总体设计主要考虑什么特征? 模块是数据说明、可执行语句等程序对象的集合,可以单独命名且可通过名字来访问 模块具有输入和输出参数传递、功能、内部数据结构局部变量和程序代码四个特性 概要设计主要考虑输入、输出参数传递和功能两个特性
4.什么是模块化?模块设计的准则? 模块化是按规定的原则将一个大型软件划分为一个个较小的、相对独立但又相关的模块 模块设计的准则 1改进软件结构提高模块独立性:在对初步模块进行合并、分解和移动的分析、精化过程中力求提高模块的内聚,降低藕合 2模块大小要适中:大约50行语句的代码,过大的模块应分解以提高理解性和可维护性;过小的模块合并到上级模块中 3软件结构图的深度、宽度、扇入和扇出要适当一般模块的调用个数不要超过5个 4尽量降低模块接口的复杂程度; 5设计单入口、单出口的模块 6模块的作用域应在控制域之内
5.变换型数据流由哪几部分组成? 变换型结构由三部分组成:传入路径、变换加工中心和传出路径
6.变换分析设计的步骤? 1区分传入、传出和变换中心三部分,划分DFD图的分界线; 2完成第一级分解:建立初始SC图的框架; 3完成第二级分解:分解SC图的各个分支; 4对初始结构图按照设计准则进行精化与改进
7.事务型数据流由哪几部分组成? 事务型结构由至少一条接受路径、一个事务中心与若干条动作路径组成
8.事务分析设计的步骤? 1在DFD图中确定事务中心、接收部分包含全部接收路径和发送部分包含全部动作路径; 2画出SC图框架把DFD图的三部分分quot;映射为事务控制模块接收模块和动作发送模块.一般得到SC图的顶层和第一层如果第一层简单可以并入顶层; 3分解和细化接收分支和动作分支完成初始的SC图; 4对初始结构图按照设计准则进行精化与改进
9.比较层次方框图与结构图是的异同? 1层次方框图描绘数据的层次结构结构图描绘的是软件结构 2二者都采用多层次矩形框树形结构层次方框图的顶层矩形框代表完整的数据结构下面各层矩形框依次代表上个框数据的子集;结构图 是在层次图的每一个方框内注明模块的名字或主要功能,方框之间的直线表示模块的调用关系,用带注解的箭头表示模块调用过程中传递的信息
10.欲开发一个银行的活期存取款业务的处理系统储户将填好的存/取款单和存折交给银行工作人员,然后由系统作以下处理; 1业务分类处理系统首先根据储户所填的存/取款单,确定本次业务的性质,并将存/取款单和存折交下一步处理; 2存款处理系统将存款单上的存款金额分别记录在存折和帐目文件中,并将现金存入现金库;最后将存折还给储户; 3取款处理系统将取款单上的取款金额分别记录在存折和帐目文件中,并从现金库提取现金;最后将现金和存折还给储户 绘制该系统的数据流图和软件结构图 顶层 一层 二层 软件结构图 第五章习题参考答案一.回答问题
1.详细设计的目的为软件结构图SC图或HC图中的每一个模块确定采用的算法和块内数据结构用某种选定的表达工具给出清晰的描述.
2.详细设计的主要任务编写软件的“详细设计说明书”.软件人员要完成的工作:1为每一个模块确定采用的算法选择某种适当的工具表达算法的过程写出模块的详细过程描述.2确定每一模块使用的数据结构.3确定模块结构的细节包括对系统外部的接口和用户界面对系统内部其它模块的接口以及关于模块输入数据、输出数据及局部数据的全部细节.4为每一个模块设计出一组测试用例以便在编码阶段对模块代码即程序进行预定的测试.
3.结构化程序设计的基本原则在详细设计中所有模块都使用单入口、单出口的顺序、选择、循环三种基本控制结构.
4.比较面向数据流和面向数据结构两类设计方法的异同相同点1遵守结构程序设计“由顶向下”逐步细化的原则并以其为共同的基础;2均服从“程序结构必须适应问题结构”的基本原则各自拥有从问题结构包括数据结构导出程序结构的一组映射规则不同点1面向数据流的设计以数据流图为基础,在分析阶段用DFD表示软件的逻辑模型,在设计阶段按数据流类型,将数据流图转换为软件结构面向数据结构的设计以数据结构为基础,从问题的数据结构出发导出它的程序结构2面向数据流的设计的最终目标是软件的最终SC图,面向数据结构的设计的最终目标是程序的过程性描述
5.比较Jackson方法和LCP方法的异同Jackson与LCP设计方法都是以数据结构为出发点,以程序的过程描述为最终目标,设计步骤基本相似它们的主要差别是1使用不同的表达工具,其中LCP方法中的表达工具Warnier图比Jackson设计方法中的表达工具Jackson图有更大的通用性;2Jackson方法的步骤和指导原则有一定的灵活性,而LCP设计方法则更加严密
6.详细设计的描述工具应具备什么功能?无论哪类描述工具不仅要具有描述设计过程,如控制流程、处理功能、数据组织及其它方面的细节的能力而且在编码阶段能够直接将它翻译为用程序设计语言书写的源程序二.给出一组数从小到大的排序算法,分别用下列工具描述其详细过程11流程图;2N—S图;3PAD图;4PDL语言PDL语言略 三.根据后面给出“卡片的分类及统计”项目说明,完成下列工作1用Jackson图表示输入与输出数据结构,找出它们之间的对应单元;2画出用Jackson图表示的程序结构;3列出程序所需用的操作,并加到上一步画出的程序结构图上;4用Jackson伪代码写出程序的过程表示输入卡片分析程序一叠输入卡片按内容分为K
1、K
2、K3三类卡片的排列规则是:以K1卡始以K2卡终起始卡之前属前置部分不含K1卡;起始卡与终了卡之间属分批部分不含K2卡如图:试用Jackson方法编一程序要求依次完成下列分析工作:-----统计起始卡前卡片的张数存入A;-----打印起始卡的内容;-----统计起始卡后出现的K1卡和K3卡总批数存入B;-----统计起始卡后出现的K1卡的张数存入C;-----统计起始卡后出现的K3卡的批数存入D;-----打印终了卡的内容;-----打印A、B、C、D四个统计值程序的过程表示及伪代码略第六章习题参考答案
1.编码的任务?使用选定的程序设计语言,把模块的过程性描述翻译为用语言书写的源程序源代码
2.对源程序基本要求?源程序要求正确可靠、简明清晰、效率高1源程序的正确性是对程序质量的最基本要求;2源程序的简明清晰,便于验证源代码和模块规格说明的一致性,容易进行测试和维护;3对于大多数模块,编码时应该把简明清晰放在第一位;4除了编码阶段产生源代码外,在测试阶段也需要编写一些测试程序,用于对软件的测试
3.程序设计语言的特点1名字说明程序中使用对象的名字,能为编译程序所检查和识别;2类型说明定义对象的类型,确定该对象的使用方式;3初始化为变量提供适当的初始值或由系统给变量赋一特殊的表明未初始化的值;4对象的局部性程序中真正需要的那部分才能访问的对象;5程序模块控制程序对象的名字;6循环控制结构如FOR语句、WHILE-DO语句、REPEAT-UNTIL语句等;7分支控制结构如IF语句、CASE语句等;8异常处理为程序运行过程中发生的错误和意外事件提供检测和处理上的帮助;9独立编译能分别编译各个程序单元
4.选择程序设计语言需要考虑的因素?1选择用户熟悉、便于用户维护的语言2选择目标系统的环境中可以提供的编译程序所能选用的语言3选择可以得到的软件工具能支持程序开发中可以利用的语言4根据工程规模的大小、目标系统应用范围,如实时应用选择Ada语言或汇编语言,系统软件开发选择C语言或汇编语言,软件开发中若含有大量数据操作则选择SQL、dBASE等数据库语言等5选择程序员熟悉的语言6选择标准化程度高、程序可移植性好的语言7根据算法与计算的复杂性、数据结构的复杂性选择如对于系统程序和结构复杂的应用程序,选择支持数组、记录或结构与指针动态数据结构的Pascal语言或C语言8根据实时要求系统需要的响应速度和效率选择相应的语言
5.编码风格的指导原则1源程序包括适当的标识符、适当的注解、程序清单的合理布局与清晰;2数据说明数据结构或数据类型的说明次序标准化;变量名称尽量有意义;对复杂的数据结构在注解中要说明在程序设计中实现这个数据结构的方法3语句的构造简单明了不要为节省空间将多个语句写在同一行;尽量避免复杂的条件及“非”条件的测试;避免大量使用循环嵌套和条件嵌套;括号的使用是为了使逻辑表达式和算术表达式的运算顺序清晰直观4效率考虑程序运行的时间存储器效率、输入/输出的效率;在处理程序正确性、清晰与效率之间的关系时先求程序正确后求快;先求清楚后求快;保持程序简单以求快;书写清楚不为“效率”牺牲清晰
6.第四代语言4GL应具备哪些的特征?1具有很强的数据管理能力,能对数据库进行有效的存取、查询和其它有关操作;2能提供一组高效的、非过程化的命令,组成语言的基本语句,编程时用户只需用这些命令说明“做什么”,不必描述实现的细节;3能满足多功能、一体化的要求为此,语言中除必须含有控制程序逻辑与实现数据库操作的语句外,还应包括生成与处理报表、表格、图形,以及实现数据运算和分析统计功能的各种语句,共同构成一个一体化的语言,以适应多种应用开发的需要第七章习题参考答案一.回答问题
1.软件测试的基本任务?软件测试是按照特定的规则,发现软件错误的过程;好的测试方案是尽可能发现迄今尚未发现错误的测试;成功的测试方案是发现迄今尚未发现错误的测试;
2.测试与调试的主要区别?11 测试从一个侧面证明程序员的失败;调试证明程序员的正确;12 测试从已知条件开始,使用预先定义的程序,且有预知的结果,不可预见的仅是程序是否通过测试;调试从不可知内部条件开始,除统计性调试外,结果是不可预见的;13 测试有计划并且要进行测试设计;调试不受时间约束;14 测试是发现错误、改正错误、重新测试的过程;调试是一个推理的过程;15 测试执行是有规程的;调试执行要求程序员进行必要的推理;16 测试由独立的测试组在不了解软件设计的件下完成;调试由了解详细设计的程序员完成;17 大多数测试的执行和设计可由工具支持;调试用的工具主要是调试器
3.人工复审的方式和作用人工复审的方式代码会审、走查和排练和办公桌检查;人工复审的作用检查程序的静态错误
4.什么是黑盒测试黑盒测试主要采用的技术有哪些黑盒测试也称为功能测试它着眼于程序的外部特征而不考虑程序的内部逻辑结构测试者把被测程序看成一个黑盒不用关心程序的内部结构黑盒测试是在程序接口处进行测试,它只检查程序功能是否能按照规格说明书的规定正常使用,程序是否能适当地接收输入数据产生正确的输出信息,并且保持外部信息如数据库或文件的完整性黑盒测试主要采用的技术有:等价分类法、边沿值分析法、错误推测法和因果图等技术
5.什么是白盒测试白盒测试主要采用的技术有哪些测试者了解被测程序的内部结构和处理过程对程序的所有逻辑路径进行测试在不同点检查程序状态确定实际状态与预期状态是否一致白盒测试主要采用的技术有路径测试技术和事务处理流程技术,对包含有大量逻辑判断或条件组合的程序采用基于逻辑的测试技术
6.路径测试技术中几种主要覆盖的含义举例说明语句覆盖:至少执行程序中所有语句一次判定覆盖:使被测程序中的每一个分支至少执行一次故也称为分支覆盖条件覆盖:执行所有可能的穿过程序的控制路流程条件组合测试:设计足够的测试用例,使每个判定中的所有可能条件取值组合至少执行一次例略
7.等价分类法的测试技术采用的一般方法举例说明11 为每个等价类编号;12 设计一个新的测试方案以尽可能多的覆盖尚未被覆盖的有效等价类重复这一步骤直到所有有效等价类被覆盖为止13 设计一个新的测试方案使它覆盖一个尚未被覆盖的无效等价类重复这一步骤直到所有无效等价类被覆盖为止例略
8.软件测试的一般步骤单元测试、子系统测试、系统测试、验收测试、平行测试
9.比较集成试的两种方式的优劣非渐增式测试方式分别测试模块再把所有模块按设计要求放在一起组成所要的程序该方法编写测试软件工作量大,模块间的接口错误发现得晚,错误定位较难诊断,总体测试有的错误容易漏掉,测试时间相对较少,可以并行测试所有模块,能充分利用人力,加快工程进度渐增式测试方式把下一个要测试的模块同已经测试好的那些模块结合起来进行测试该方法利用已测试过的模块作测试软件开销小,较早发现模块间的接口错误,错误定位往往和最近入的模块相关,对已测试好的模块可在新加入模块的条件下受到新的检验,测试更彻底,需要较多的测试时间,不能并行测试总的来说,渐增式测试方法比较好
10.软件测试的策略11 在任何情况下都应使用边界值分析的方法12 必要时用等价类划分法补充测试方案13 必要时再用错误推测法补充测试方案14 对照程序逻辑,检查已设计出的测试方案15 根据对程序可靠性的要求采用不同的逻辑覆盖标准,再补充一些测试方案二.某电力公司有A、B、C、D共四类收费标准,并规定,居民用电每月200度以下按A类收费,200度以上按B类收费动力电以每月1万度为分界,非高峰用电不足1万度按B类收费,达到或超过1万度按C类收费高峰用电不足1万度按C类收费,达到或超过1万度按D类收费试用基于逻辑的测试方法为它设计足够的测试用例实现条件组合的完全覆概规则号123456居民用电200度以下Y 200度以上 Y 动力用电非高峰1万度以下 Y 1万度以上 Y 高峰1万度以下 Y 1万度以上 Y 收费标准A类▲ B类 ▲▲ C类 ▲▲ D类 ▲ 测试用例用电类型输入数据预期结果居民用电90度/月A110度/月B 动力用电非高峰8000度/月B12000度/月C高峰9000度/月C11000度/月D 三.如图显示某程序的逻辑结构试为它设计足够的测试用例,分别实现对程序的判定覆概、条件覆概和条件组合覆概设计测试方案覆盖种类需满足的条件测试数据期望结果 判定覆盖A1B=0A=2B=0执行S1A1B¹0或A£1B=0或A£1B¹0A=2B=1或A=1B=0或A=1B=1 执行S2 条件覆盖以下四种情况各出现一次 A1B=0A=2,B=0执行S1A£1B¹0A=1,B=1执行S2 条件组合覆盖A1B=0A=2B=0执行S1A1B¹0A=2B=1执行S2A£1B=0A=1B=0执行S2A£1B¹0A=1B=1执行S2 四.某城市电话号码由三部分组成它们的名称和内容分别是地区码空白或三位数字;前缀非‘0’或‘1’的三位数字;后缀4位数字假定被测程序能接受一切符合上述规定的电话号码,拒绝所有不符合规定的电话号码根据该程序的规格说明,作等价类的划分,并设计测试方案
1.划分等价类输入条件有效等价类无效等价类地区码
1.空白;
2.三位数;
1. 有非数字字符;
2.少于三位数字;
3.多于三位数字前缀
3.从200到999之间的三位
4.有非数字字符;
5.起始位为‘0’;
6.起始位为‘1’;
7.少于三位数字;
8.多于三位数字后缀
4.四位数字
9.有非数字字符;
10.少于四位数字;
11.多于四位数字 设计测试方案方案内容输入预期输出地区码前缀后缀1空白200~999之间的三位数字四位数字276-2345有效2三位数字四位数字635805-9321有效3有非数字字符 20A723-4567无效4少于三位数字 33234-5678无效5多于三位数字 5555345-6789无效6 有非数字字符 3455A2-3456无效7 起始位为‘0’ 345012-3456无效8 起始位为‘1’ 345132-3456无效9 少于三位数字 34592-3456无效10 多于三位数字 3454562-3456无效11 有非数字字符345342-3A56无效12 少于四位数字345342-356无效13 多于四位数字345562-34567无效第八章软件维护 习题答案
1.为什么说软件的维护是不可避免的? 因为软件的开发过程中,一般很难检测到所有的错误,其次软件在应用过程中需要随用户新的要求或运行环境的变化而进行软件的修改或完成功能的增删等,为了提高软件的应用水平和使用寿命,软件的维护是不可避免的
2.软件的维护一般分为哪几类? 改正性维护满足用户对已开发产品的性能与运行环境不断提高的要求,进而达到延长软件寿命的目的 适应性维护对程序使用期间发现的程序错误进行诊断和改正的过程,配合变化了的环境进行修改软件的活动; 完善性维护满足用户在使用过程中提出增加新的功能或修改已有功能的建议而进行的工作; 预防性维护为了改善未来的可维护性或可靠性而修改软件的工作
3.影响软件维护的因素有哪些? 开发方法采用模块化详细设计文档有助于理解软件的结构、界面功能和内部流程;开发过程中严格而科学的管理规划及清晰可靠的文档资料对发生错误后的理解与纠错是至关重要的;开发过程中模块的独立程度越高,对软件修改越容易,对软件的改进和移植越方便 开发条件软件开发及维护人员的水平决定了软件开发的质量和维护的效率;开发过程中使用标准的程序设计语言和标准的操作系统接口,可以大大提高软件的可维护性;在测试过程中用例的有效性,可极大地减少软件存在的错误;其次使用规范化的文档资料可为维护提供更好的依据
4.软件维护困难主要表现在什么方面? 1一般来讲,维护人员对开发人员写的程序及文档,理解都比较困难,对维护工作不会喜欢; 2维护持续时间都很长,在开发人员不在现场的轻快下,维护软件通常是很困难的; 3绝大多数软件在设计时对将来的软件修改都没有考虑或考虑不多,尤其未能在设计中强调并认真解决好模块的独立性,使软件的修改既困难又易发生差错
5.决定软件可维护性的因素? 1软件的可理解性、可测试性、可修改性; 2文档描述符合要求、用户文档简洁明确、系统文档完整并且标准
6.软件价格应该计入维护成本吗?为什么? 在软件的生命周期中,软件维护的工作量非常大,不同应用领域的维护成本差别也很大一般大型软件的维护成本远远高于开发成本若干倍因此软件价格中应该计入维护成本
7.对前面各章中分析的各应用系统,提出改进和扩充功能的要求? 1教材销售采购系统; 2图书管理系统; 3房产管理系统 略第九章软件工程管理 习题答案
1.软件工程管理的内容? 1费用管理:对软件开发进行成本核算使软件生产按照商品生产的规律办事包括:以简单、科学方法估算软件开发费用作为签定开发合同的根据;管理开发费用的有效使用即用经济手段来保证产品如期按质完成 2质量管理:按项目的质量保证计划确保各个开发阶段的开发和维护工作全部按软件工程的规范进行保证软件产品的质量 3配置管理:通过对于程序、文档和数据的各种版本所进行的管理,保证资料的完整性与一致性 4项目管理制定《项目实施计划》,按照计划的内容组织和实施软件的工程化生产最终目标是以合理的费用和进度,圆满完成计划所规定的软件项目
2.软件项目有哪些特点? 1软件项目与其他任何产业项目不同,它是算法、思想、概念、组织、流程、效率、优化等的融合体; 2开发软件项目产品在多数情况下用户给不出明确的想法和要求 3在开发过程中,程序及其相关的文档资料常常需要修改,在修改过程中又可能带来新的问题,且这些问题要在很久以后才会发现 4在研制开发过程中,文档资料是不可缺少的,但工作量又是巨大的往往也是人们不愿去作的 5参加软件项目的工作人员,要求具有一定的业务水平和实际工作经验,而很难完全避免的人员流动,对工作的影响是很大的离开的人员不仅带走了重要的信息,而且带走了工作经验
3.软件成本估算的一般方法? 自顶向下估计:首先估算出项目总的开发成本,然后在项目内部进行成本分配由少数专家参与,依靠他们过去的经验,将要开发的软件与过去开发过的软件进行类比,以估计新的软件开发所需要的工作量和成本 自底向上估计:将开发任务分成若干子任务子任务又分成子子任务直到每一个单元内容足够明确为止;把各个任务单元的成本估计出来汇合成项目的总成本该方法得到的结果比较接近实际
4.为什么在软件开发中,不能用简单增加人员的方法来缩短开发时间? 大量软件开发实践说明:向一个已经延迟的项目追加开发人员可能使它完成得更晚因为当开发人员以算术级数增长时,而人员之间的通信将以几何级数增长,往往得不偿失
5.影响软件质量的主要因素有哪些? 1产品运行:正确性、风险性、效率、完整性、健壮性和可用性; 2产品修改:可理解性、可维护性、灵活性、可测试性; 3产品转移可移植性、可重用性和互运行性
6.本章第四节的例子是某个软件项目的PERT图 1找出关键路径和完成项目的最早时间; 2标出每项活动的最早起止时间与最迟起止时间 见该章教案举例
7.将上题的内容改用Gantt图来表示 见该章教案举例第十章软件工程环境 习题答案
1.软件工具是什么?按照软件生存周期可将其分为几类? 软件工具是指为支持计算机软件及其文档的开发、维护、模拟、移植或管理而研制的程序系统按照软件生存周期可将其分为如下几类 1需求分析如数据流图绘制与分析工具、状态转换图绘制与分析工具、面向对象的模型和分析工具、快速原型构造工具、数据字典与数据库工具等 2软件设计如HIPO图、PDL程序设计语言或PAD问题分析图支持工具等 3编码集成化的程序员工作平台如各种正文编辑器和常规的编译程序、汇编程序、连结程序及符号调试器等 4软件测试如静态分析器、动态覆盖率测试器、测试用例生成器、测试报告生成器及环境模拟器等 5软件维护如反汇编程序、反编译程序、程序结构分析器、源程序格式化工具、文档生成工具、源程序至PAD问题分析图或流程图的自动转换工具等
2.评价软件工具的原则 1易用性:友好的用户界面,用户乐于使用; 2对开发方法的支持能满足预期的任务和功能需求,且能支持完成该任务所遵循的方法学; 3稳健性:具备自检测机制即使在故障情况下也不会导致严重后果; 4性能:能使资源得到充分有效的利用; 5工具结构柔性:工具结构是柔软的、可修改的和可扩充的
3.什么是软件开发环境?按技术发展方向分为哪几类环境? 将一组相关的软件工具按照一定的软件开发方法、软件生产和维护模型有机的组合起来,为特定的领域所使用,以支持从需求分析、设计、编码、测试直到维护的整个软件生命周期的计算机辅辅助开发程序系统称为软件开发环境 按技术发展方向软件开发环境可分为以语言为中心的环境、面向结构化的环境和工具箱环境
4.工具箱类软件工具的基本特点? 1在某种OS基础上通过一组小的实用工具构成; 2虽然各工具之间相互独立,但系统能提供统一的用户命令界面及工具之间统一的数据交换方式; 3工具箱中各工具之间是相互独立的,用户可根据需要进行灵活的增加和裁减; 4工具箱环境中一般除了包括支持编码阶段的工具如编辑程序、编译程序、汇编程序、连结程序调试程序等外,还可包括支持大型软件开发方面的工具; 5由于工具箱环境具有较强的通用性和灵活性,因而目前商品化的算机系系统上配置的软件环境大多属于这一类如UNIX程序设计环境、及VAX/VNSSET、PCDE、APCE等程序设计环境
5.软件开发环境的组成与各成分的作用? 软件开发环境的构成:交互式人机界面、工具集及软件环境数据库 交互式人机界面:人机界面也称用户界面或人机对话是用户与计算机系统之间相互交流的中间媒介 工具集工具集中软件工具是构成软件开发环境的基本成分包含在软件开发环境中的工具不是各自封闭和分离的,而是与某种软件开发方法或某种软件加工模型相适应,并以一种综合的、一致的和整体连贯的形态来支持软件开发的全过程 软件环境数据库是各个软件工具之间共享数据及相互连结的统一媒介
6.软件开发环境数据库在软件开发中的作用? 软件环境数据库是用于支持软件项目的大型数据库;软件环境数据库中主要存储软件开发过程中产生的有关产品或半成品的数据及各种项目数据,如源程序、测试数据和各种文档等,它构成软件开发和维护过程中所有项目数据的集中化的存储设施是集成化软件开发环境的核心组成部分也是各个软件工具之间共享数据及相互连结的统一媒介
7.集成化项目支持环境IPSE的主要特征是什么? 1集成化和相互兼容的工具集; 2支持项目的管理和控制; 3支持配置管理; 4支持多种语言的软件开发; 5支持硬件开发; 6允许宿主机和目标机使用分布式系统
8.CASE的含义是什么? CASE是计算机辅助软件工程的简称简单的说可以将CASE理解为:CASE=软件工程+自动化工具.从狭义角度解释它是一组工具和方法的结合;从广义角度解释它是辅助软件开发的任何计算机技术;从学术研究角度解释:它是软件开发方法、软件开发管理和软件工具等方面多年研究和发展的产物;从软件产业角度解释它是种类繁多的软件开发和系统集成的产品和软件工具的集合
9.CASE工具一般分为几类?有什么区别? CASE工具可以理解为除OS外的所有软件工具的总称按对软件过程的支持范围CASE工具分为三类一是工具:支持单个任务;二是工作台支持某一软件过程或一个过程中的某些活动;三是环境支持某些软件过程及相关的大部分活动
10.工作台实现软件工具集成的方式? 工作台实现软件工具集成的方式是通过共享文件、共享仓库或共享数据结构来集成作业题面向对象分析实践下面是自动售货机系统的需求陈述,试建立它的对象模型、动态模型和功能模型自动售货机系统是一种无人售货系统售货时,顾客把硬币投入机器的投币口中,机器检查硬币的大小、重量、厚度及边缘类型有效的硬币是一元币、五角币、五分币、二分币、一分币其他货币被认为是假币机器拒绝接受假币,并将其从退币孔退出当机器接受了有效的硬币之后,就把硬币送入硬币储藏器中顾客支付的货币根据硬币的面值进行累加自动售货机装有货物分配器每个货物分配器中包含零个或多个价格相同的货物顾客通过选择货物分配器来选择货物如果货物分配器中有货物,而且顾客支付的货币值不小于该货物的价格,货物将被分配到货物传送孔送给顾客,并将适当的零钱返还到退币孔如果分配器是空的,则和顾客支付的货币值相等的硬币将被送回到退币孔如果顾客支付的货币值少于所选择的分配器中货物的价格,机器将等待顾客投进更多的货币如果顾客决定不买所选择的货物,他投放进的货币将从退币孔中退出参考资料《软件工程》张海藩清华大学出版社2009年第一版面向对象的分析面向对象分析方法的核心思想是利用面向对象概念和方法为软件需求构造一组相关模型(对象模型,动态模型和功能模型),来获得关于问题域的全面认识这三个模型从不同的角度对系统进行描述,其中对象模型描述了系统静态的、结构化的数据性质;动态模型描述了系统顺势的、行为化的控制性质;功能模型描述了变化的系统的功能性质这三个模型都涉及到数据控制和操作等共同的概念,但每种模型描述的侧重有所不同它们各自以不同侧面反应系统的实质内容,综合起来则全面反映了目标系统的需求对象模型是三个模型中最关键的它的作用是描述系统的静态结构,包括构成系统的类和对象、它们的属性和操作以及它们之间的联系UML中类图适用于建立对象模型,状态图适用于建立动态模型每个类的动态行为用一张状态图来表示,各个类的状态图通过事件合并起来,构成系统的动态模型也就是说,动态模型是基于事件共享而相互关联的一组状态图的集合建立对象模型大体上按照下列顺序进行:寻找问题域内的对象,识别出对象间的关系、定义属性和服务事实上,分析工作不可能严格按照预定顺序进行,系统的模型往往需要反复构造多遍才能建成注对象硬币计算器和对象硬币检测器可以作为对象自动售货器的一部分,它们的属性作为自动售货器的属性建立动态模型对于仅存数静态数据的系统来说,动态模型并没有什么实际意义然而在开发交互式系统时,动态模型却起着很重要的作用如果收集输入信息是目标系统的一项主要工作,则在开发这类应用系统时建立正确的动态模型是至关重要的建立动态模型的步骤1编写典型的对话脚本;2从脚本中提取出事件,联系该事件与其目标对象;3组织事件的顺序和状态采用状态图描绘;4比较各个不同对象的状态图,检查对象之间的一致性,确保事件之间的匹配#0;#0;#0;#0;提示投币检查硬币提示是假币,退币存储硬币,计算货币总值确认投完硬币请求选择货物检测货物存量提示无货计算比较货币总值和货物价格确认确认顾客购买送出货物,请求取货退币请求取退币提示显示交易完毕提示货物不足,确认顾客购买假币投币真币是选择货物否无货小于不购买购买不购买功能模型 功能模型描述了系统的所有计算功能模型指出发生了什么,动态模型确定什么时候发生,而对象模型确定发生的客体功能模型表明一个计算如何从输入值得到输出值,它不考虑计算的次序功能模型由多张数据流图组成数据流图用来表示从源对象到目标对象的数据值的流向,它不包含控制信息,控制信息在动态模型中表示,同时数据流图也不表示对象中值的组织,值的组织在对象模型中表示数据流图中包含有处理、数据流、动作对象和数据存储对象
1.处理 数据流图中的处理用来改变数据值最低层处理是纯粹的函数,一张完整的数据流图是一个高层处理
2.数据流 数据流图中的数据流将对象的输出与处理、处理与对象的输入、处理与处理联系起来在一个计算机中,用数据流来表示一中间数据值,数据流不能改变数据值
3.动作对象 动作对象是一种主动对象,它通过生成或者使用数据值来驱动数据流图
4.数据存储对象 数据流图中的数据存储是被动对象,它用来存储数据它与动作对象不一样,数据存储本身不产生任何操作,它只响应存储和访问的要求#0;#0;#0;等待顾客投币检查硬币退币退假币分配货物,找零货物价格有效币特征顾客投币顾客取消购买,退币送入硬币储藏器计算面值判断货币是否足够判断分配器货物存量顾客假币顾客假币有效币货币总值硬币选择货物无货有货足够不足硬币货物,硬币硬币。