1、《软件工程导论》课后习题答案 第一章 软件工程概论 1.什么是软件危机? 软件危机是指在计算机软件开发与维护过程中所遇到一系列严重问题。这些问题表现在以下几个方面: (1)用户对开发出软件很难满意。 (2)软件产品质量往往靠不住。 (3)一般软件很难维护。 (4)软件生产效率很低。 (5)软件开发成本越来越大。 (6)软件成本及开发进度难以估计。 (7)软件技术发展远远满足不了计算机应用普及及深入需要。 2.为什么会产生软件危机? (1) 开发人员方面,对软件产品缺乏正确认识,没有真正理解软件产品是一个完整配置组成。造成
2、开发中制定计划盲目、编程草率,不考虑维护工作必要性。 (2) 软件本身方面,对于计算机系统来说,软件是逻辑部件,软件开发过程没有统一、公认方法论与规范指导,造成软件维护困难。 (3) 尤其是随着软件规模越来越大,复杂程度越来越高,原有软件开发方式效率不高、质量不能保证、成本过高、研制周期不易估计、维护困难等一系列问题更为突出,技术发展已经远远不能适应社会需求。 3.怎样克服软件危机? (1) 充分吸收与借鉴人类长期以来从事各种工程项目中积累行之有效有效原理、概念、技术及方法,特别是吸取几十年来人类从事计算机硬件研究与开发经验教训。在开发软件过程中努力作到良好组织,严格管理
3、相互友好协作。 (2) 推广在实践中总结出来开发软件成功技术与方法,并研究更好、更有效技术与方法,尽快克服在计算机系统早期发展阶段形成一些错误概念与作法。 (3) 根据不同应用领域,开发更好软件工具并使用这些工具。将软件开发各个阶段使用软件工具集合成一个整体,形成一个很好软件开发支环环境。 总之为了解决软件危机,既要有技术措施(方法与工具),又要有必要组织管理措施。 4.构成软件项目最终产品: 应用程序、系统程序、面向用户文档资料与面向开发者文档资料。 5.什么是软件生存周期? 软件生存周期是指从软件定义、开发、使用、维护到淘汰全过程。 6.软件生存周期为什么
4、划分成阶段? (1) 任何一个阶段具体任务不仅独立,而且简单,便于不同人员分工协作,从而降低整个软件开发工作困难程度。 (2) 可以降低每个阶段任务复杂程度,简化不同阶段联系,有利于工程组织管理,也便于采用良好技术方法。 (3) 使软件开发全过程以一种有条不紊方式进行,保证软件质量,特别是提高了软件可维护性。 7.应该怎样来划分阶段? (1)每一个阶段任务尽可能独立; (2)同一阶段内任务性质尽可能相同; (3)每一个阶段任务开始与结束有严格标准。 8.软件开发模型有几种?它们开发方法有可特点? 软件开发模型有瀑布型、渐增型与变换型。 瀑布
5、型开发方法是按照软件生存周期划分依次实施,每一个阶段有明确规定任务。它特点: (1)各个阶段顺序性与依赖性; (2)划分逻辑设计及物理设计,尽可能推迟程序物理实现; (3)每个阶段必须完成规定文档,对其中问题通过复审及早发现,及早解决。 渐增型开发方法及特点: (1) 从部分需求出发,先建立一个不完全系统,通过测试运行该系统取得经验与信息反馈,加深对软件需求理解,进一步使系统扩充与完善。如此反复,直至软件人员与用户对所设计完成软件系统满意为止。 (2) 在渐增型开发下软件是随软件开发过程而逐渐形成。 (3) 渐增型开发方法适合于知识型软件开
6、发,设计系统时对用户需求认识开始不是很清楚,需要在开发过程中不断认识、不断获得新知识去丰富与完善系统。多数研究性质试验软件,一般采用此方法。 变换型开发方法及特点: (1)从软件需求形式化规格说明出发,经过一系列程序变换,得到最终程序系统。 (2)该方法必须有严格数学理论与形式化技术支持。 9.什么是软件工程? 软件工程是指导计算机软件开发与维护工程学科。 (1) 它采用工程概念、原理、技术与方法来开发与维护软件; (2) 它将管理技术及当前经过时间考验而证明是正确技术方法结合起来; (3) 它强调使用生存周期方法学与结构分析与结构技术;
7、 (4) 经过人们长期努力与探索,围绕着实现软件优质高产这个目标,从技术到管理两个方面做了大量努力,逐渐形成了"软件工程学"这一新学科。 10.什么是软件工程环境: 方法及工具结合,加上配套软、硬件支持称为软件工程环境。它能支持开发者按照软件工程方法,全面完成生存周期中各项任务。 第二章 可行性研究 习题答案 1. 问题定义任务与主要工作? 问题定义任务:将用户提出要求具体化、定量化;确定研制系统范围,明确研制边界。 问题定义阶段工作: (1) 通过调查研究,了解系统需求; (2) 确定系统功能需求、性能需求、可靠性需求、安全及保密性、资源、开发费用及开发
8、进度等需求; (3) 问题定义阶段产品--系统目标及范围说明书。 2.可行性研究目? 确定在问题定义中所提出问题是否值得去解,在限制条件下,问题能否解决。 3.可行性研究任务? (1) 进一步分析与澄清问题定义,在澄清问题基础上,导出系统逻辑模型; (2) 从系统逻辑模型中,选择问题若干种主要解法,研究每一种解法可行性,为以后行动提出建议; (3) 如果问题没有可行解,建议停止系统开发;如果问题有可行解,应该推荐一个较好解决方案,并为工程制定一个初步计划。 4.可行性研究包括哪几方面内容? (1)技术可行性:现有技术能否实现本系统,现有技术人员能否胜任
9、开发系统资源能否满足; (2)经济可行性:经济效益是否超出开发成本; (3)操作可行性:系统操作在用户内部行得通吗? (4)法律可行性:新系统开发是否会侵犯他人、集体或国家利益,是否违反国家法律。 5.可行性研究步骤? (1)复查系统规模与目标; (2)研究目前正在使用系统,总结现有系统优劣,提出新系统雏形; (3)导出新系统高层逻辑模型; (4)推荐建议方案; (5)推荐行动方针; (6)书写计划任务书(可行性报告); (7)提交审查。 6. 可行性研究报告主要内容? 可行性分析结果是可行性研究报告,内容包括:
10、 (1) 系统概述:说明开发系统名称,提出单位与开发单位。 (2) 可行性研究前提:系统目标;要求;约束与限制;可行性研究基本准则等。 (3) 对现有系统分析:处理流程,图示说明现有系统处理流程与数据流程;现有系统存在问题。 (4) 系统需求:主要功能;主要性能及其要求;操作要求;信息要求;限制性要求。 (5) 建议系统:系统目标;处理流程;系统结构,功能,性能;系统技术可行性;投资与效益分析;操作可行性;法律可行性。 (6) 其它可选方案:及国内外同类型方案比较;提出一两个可行性方案供论证与探讨。 (7) 制定下一阶段预算。 (8) 结论性意见:由
11、用户方、设计方与投资方共同签署意见。 第三章 需求分析 习题答案 1.需求分析描述工具有哪些? 有数据流图、数据字典、判定表、判定树、结构化自然语言、层次方框图、Warnier图、IPO图与需求描述语言等。 2.需求分析基本任务是什么? 准确定义未来系统目标,确定为了满足用户需要系统必须做什么。 3.怎样建立目标系统逻辑模型?要经过哪些步骤? 建立目标系统逻辑模型过程也就是数据流图分解过程。它导出过程如图: 4.什么是结构化分析?它结构化表达在哪里? 结构化分析:使用数据流程图、数据字典、结构化英语、判定表与判定树等工具,来建立一种新、称为结构化说明书目标文档
12、需求规格说明书。 结构化表达在将软件系统抽象为一系列逻辑加工单元,各单元之间以数据流发生关联。 5.软件需求规格说明书由哪些部分组成? 组成包括: (1) 引言:编写目、背景说明、术语定义及参考资料等。 (2) 概述主要功能、约束条件或特殊需求。 (3) 数据流图及数据字典。 (4) 用户接口、硬件接口及软件接口。 (5) 性能需求、属性等。 (6) 其它需求,如数据库、操作及故障处理等。 6.为什么数据流图要分层?画分层DFD要遵循哪些原则? 分层目:便于逐步细化、结构清晰。 画分层DFD要遵循哪些原则: (1)父图及子
13、图之间数据要平衡。 (2)分解深度与层次达到使加工足够简单、易于理解基本加工为止。 (3)区分局部文件与局部外部项(局限于数据流中某一层或某几层文件与外部项)。 (4)不要把控制流作为数据流。 (5)忽略琐碎枝节。 (6)每个数据流要有一个合适名字,尽量使用现实系统中有具体意义名字。 7.系统流程图及数据流程图有什么区别? 系统流程图描述系统物理模型工具,数据流程图描述系统逻辑模型工具。 系统流程图从系统功能角度抽象描述系统各个部分及其相互之间信息流动情况。 数据流程图从数据传送与加工角度抽象描述信息在系统中流动与数据处理工作状况。 8.数据
14、字典包括哪些内容?它作用是什么? 数据字典是描述数据流图中数据信息集合。它对数据流图上每一个成分:数据项、文件(数据结构)、数据流、数据存储、加工与外部项等给以定义与说明;它主要由数据流描述、加工描述与文件描述三部分组成。对用户来讲,数据字典为他们提供了数据明确定义;对系统分析员来讲,数据字典帮助他们比较容易修改已建立系统逻辑模型。 9.描述加工逻辑工具有哪些? 有决策树(又称判定树)、决策表(又称判断表)与结构化语言等。 10.某单位拟开发一个计算机房产管理系统,要求系统具有分房、 调房、退房与查询统计等功能。房产科将用户申请表输入系统 后,系统首先检查申请表合法性,对不合法
15、申请表,系统拒绝接收;对合法申请表根据类型分别进行处理。 (1) 如果是分房申请,则根据申请者情况(年龄、工龄、职称、职务、家庭人口等)计算其分数,当分数高于阀值分数时,按分数高低将申请单插到分房队列适当位置。在进行分房时,从空房文件中读出空房信息,如房号、面积、等级、单位面积房租等,把好房优先分给排在分房队列前面符合该等级房条件申请者;从空房文件中删掉这个房号信息,并从分房队列中删掉该申请单,再把此房号信息与住户信息一起写到住房文件中,输出住房分配单给住户,同时计算房租,并将算出房租写到房租文件中。 (2) 如果是退房申请,则从住房文件与房租文件中删除有关信息,再把此房号信息
16、写到空房文件中。 (3) 如果是调房申请,则根据申请者情况确定其住房等级,然后在空房文件中查找属于该等级空房,退掉原住房,再进行及分房类似处理。 (4) 住户可以向系统查询目前分房阀值分数,居住某类房屋条件,某房号单位面积及房租等信息。房产科可以要求系统打印住房情况统计表,或更改某类房屋居住条件、单位面积与房租等。 用数据流图描绘该系统功能需求;在数据字典中给出主要数据流、文件与加工说明。 参考第四章4.5应用举例教案之二分析。 第四章 总体设计 习题答案 1. 系统设计包括哪两个阶段? 系统设计包括总体设计及详细设计两个阶段。 2. 总体设计主要任务是什
17、么? 总体设计主要任务是完成软件结构设计,确定系统模块及其模块之间关系。 3. 什么是模块?模块具有哪几个特征?总体设计主要考虑什么特征? 模块是数据说明、可执行语句等程序对象集合,可以单独命名且可通过名字来访问。 模块具有输入与输出(参数传递)、功能、内部数据结构(局部变量)与程序代码四个特性。 概要设计主要考虑输入、输出(参数传递)与功能两个特性。 4. 什么是模块化?模块设计准则? 模块化是按规定原则将一个大型软件划分为一个个较小、相对独立但又相关模块。 模块设计准则: (1) 改进软件结构, 提高模块独立性:在对初步模块进行合并、分解与移动
18、分析、精化过程中力求提高模块内聚,降低藕合。 (2) 模块大小要适中:大约50行语句代码,过大模块应分解以提高理解性与可维护性;过小模块,合并到上级模块中。 (3) 软件结构图深度、宽度、扇入与扇出要适当。一般模块调用个数不要超过5个。 (4) 尽量降低模块接口复杂程度; (5) 设计单入口、单出口模块。 (6) 模块作用域应在控制域之内。 5. 变换型数据流由哪几部分组成? 变换型结构由三部分组成:传入路径、变换(加工)中心与传出路径。 6. 变换分析设计步骤? (1) 区分传入、传出与变换中心三部分,划分DFD图分界线; (2) 完成第一
19、级分解:建立初始SC图框架; (3) 完成第二级分解:分解SC图各个分支; (4) 对初始结构图按照设计准则进行精化及改进。 7. 事务型数据流由哪几部分组成? 事务型结构由至少一条接受路径、一个事务中心及若干条动作路径组成。 8. 事务分析设计步骤? (1) 在DFD图中确定事务中心、接收部分(包含全部接收路径)与发送部分(包含全部动作路径); (2) 画出SC图框架,把DFD图三部分分?quot;映射"为事务控制模块,接收模块与动作发送模块.一般得到SC图顶层与第一层(如果第一层简单可以并入顶层); (3) 分解与细化接收分支与动作分支,完成初始SC
20、图; (4) 对初始结构图按照设计准则进行精化及改进。 9. 比较层次方框图及结构图是异同? (1) 层次方框图描绘数据层次结构, 结构图描绘是软件结构。 (2) 二者都采用多层次矩形框树形结构。层次方框图顶层矩形框代表完整数据结构, 下面各层矩形框依次代表上个框数据子集;结构图 是在层次图每一个方框内注明模块名字或主要功能,方框之间直线表示模块调用关系,用带注解箭头表示模块调用过程中传递信息。 10.欲开发一个银行活期存取款业务处理系统:储户将填好存/取款单与存折交给银行工作人员,然后由系统作以下处理; (1)业务分类处理:系统首先根据储户所填存/取款单,确定本
21、次业务性质,并将存/取款单与存折交下一步处理; (2)存款处理:系统将存款单上存款金额分别记录在存折与帐目文件中,并将现金存入现金库;最后将存折还给储户; (3)取款处理:系统将取款单上取款金额分别记录在存折与帐目文件中,并从现金库提取现金;最后将现金与存折还给储户。 绘制该系统数据流图与软件结构图。 顶层 一层 二层 软件结构图 第五章 习题参考答案 一.回答问题 1.详细设计目? 为软件结构图(SC图或HC图)中每一个模块确定采用算法与块内数据结构,用某种选定表达工具给出清晰描述. 2.详细设计主要任务? 编写软件“详细设计说明书”.
22、软件人员要完成工作: (1) 为每一个模块确定采用算法, 选择某种适当工具表达算法过程,写出模块详细过程描述. (2) 确定每一模块使用数据结构. (3) 确定模块结构细节,包括对系统外部接口与用户界面,对系统内部其它模块接口,以及关于模块输入数据、输出数据及局部数据全部细节. (4) 为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定测试. 3.结构化程序设计基本原则? 在详细设计中所有模块都使用单入口、单出口顺序、选择、循环三种基本控制结构. 4.比较面向数据流与面向数据结构两类设计方法异同? 相同点: (1) 遵守结构程序设计“由顶向
23、下”逐步细化原则,并以其为共同基础; (2) 均服从“程序结构必须适应问题结构”基本原则,各自拥有从问题结构(包括数据结构)导出程序结构一组映射规则。 不同点: (1) 面向数据流设计以数据流图为基础,在分析阶段用DFD表示软件逻辑模型,在设计阶段按数据流类型,将数据流图转换为软件结构。面向数据结构设计以数据结构为基础,从问题数据结构出发导出它程序结构。 (2) 面向数据流设计最终目标是软件最终SC图,面向数据结构设计最终目标是程序过程性描述。 5.比较Jackson方法与LCP方法异同? Jackson及LCP设计方法都是以数据结构为出发点,以程序过程描述为最终目标,设计
24、步骤基本相似。它们主要差别是: (1)使用不同表达工具,其中LCP方法中表达工具Warnier图 比Jackson设计方法中表达工具Jackson图有更大通用性; (2)Jackson方法步骤与指导原则有一定灵活性,而LCP设计 方法则更加严密。 6.详细设计描述工具应具备什么功能? 无论哪类描述工具不仅要具有描述设计过程,如控制流程、处理功能、数据组织及其它方面细节能力,而且在编码阶段能够直接将它翻译为用程序设计语言书写源程序。 二.给出一组数从小到大排序算法,分别用下列工具描述其详细过程: (1) (1) 流程图;(2)N—S图;(3)PAD图;(
25、4)PDL语言。 PDL语言略 三.根据后面给出“卡片分类及统计”项目说明,完成下列工作: (1)用Jackson图表示输入及输出数据结构,找出它们之间对应单元; (2)画出用Jackson图表示程序结构; (3)列出程序所需用操作,并加到上一步画出程序结构图上; (4)用Jackson伪代码写出程序过程表示。 输入卡片分析程序。一叠输入卡片按内容分为K1、K2、K3三类,卡片排列规则是:以K1卡始,以K2卡终。起始卡之前属前置部分,不含K1卡;起始卡及终了卡之间属分批部分,不含K2卡。如图: 试用Jackson方法编一程序,要求依
26、次完成下列分析工作: -----统计起始卡前卡片张数,存入A; -----打印起始卡内容; -----统计起始卡后出现K1卡与K3卡总批数,存入B; -----统计起始卡后出现K1卡张数,存入C; -----统计起始卡后出现K3卡批数,存入D; -----打印终了卡内容; -----打印A、B、C、D四个统计值。 程序过程表示及伪代码略 第六章 习题参考答案 1. 编码任务? 使用选定程序设计语言,把模块过程性描述翻译为用语言书写源程序(源代码)。 2. 对源程序基本要求? 源程序要求:正确可靠、简明清晰、效
27、率高。 (1) 源程序正确性是对程序质量最基本要求; (2) 源程序简明清晰,便于验证源代码与模块规格说明一致性,容易进行测试与维护; (3) 对于大多数模块,编码时应该把简明清晰放在第一位; (4) 除了编码阶段产生源代码外,在测试阶段也需要编写一些测试程序,用于对软件测试。 3. 程序设计语言特点? (1) 名字说明:程序中使用对象名字,能为编译程序所检查与识别; (2) 类型说明:定义对象类型,确定该对象使用方式; (3) 初始化:为变量提供适当初始值或由系统给变量赋一特殊表明未初始化值; (4) 对象局部性:程序中真正需要那部分
28、才能访问对象; (5) 程序模块:控制程序对象名字; (6) 循环控制结构:如FOR语句、WHILE-DO语句、REPEAT-UNTIL语句等; (7) 分支控制结构:如IF语句、CASE语句等; (8) 异常处理:为程序运行过程中发生错误与意外事件提供检测与处理上帮助; (9) 独立编译:能分别编译各个程序单元。 4. 选择程序设计语言需要考虑因素? (1) 选择用户熟悉、便于用户维护语言。 (2) 选择目标系统环境中可以提供编译程序所能选用语言。 (3) 选择可以得到软件工具,能支持程序开发中可以利用语言。 (4) 根据工程规模
29、大小、目标系统应用范围,如实时应用选择Ada语言或汇编语言,系统软件开发选择C语言或汇编语言,软件开发中若含有大量数据操作则选择SQL、dBASE等数据库语言等。 (5) 选择程序员熟悉语言。 (6) 选择标准化程度高、程序可移植性好语言。 (7) 根据算法及计算复杂性、数据结构复杂性选择。如对于系统程序与结构复杂应用程序,选择支持数组、记录(或结构)及指针动态数据结构Pascal语言或C语言。 (8) 根据实时要求系统需要响应速度与效率选择相应语言。 5. 编码风格指导原则。 (1) 源程序:包括适当标识符、适当注解、程序清单合理布局及清晰;
30、 (2) 数据说明:数据结构或数据类型说明次序标准化;变量名称尽量有意义;对复杂数据结构在注解中要说明在程序设计中实现这个数据结构方法。 (3) 语句构造简单明了:不要为节省空间将多个语句写在同一行;尽量避免复杂条件及“非”条件测试;避免大量使用循环嵌套与条件嵌套;括号使用是为了使逻辑表达式与算术表达式运算顺序清晰直观。 (4) 效率:考虑程序运行时间存储器效率、输入/输出效率;在处理程序正确性、清晰及效率之间关系时先求程序正确后求快;先求清楚后求快;保持程序简单以求快;书写清楚,不为“效率”牺牲清晰。 6. 第四代语言(4GL)应具备哪些特征? (1)
31、 具有很强数据管理能力,能对数据库进行有效存取、查询与其它有关操作; (2) 能提供一组高效、非过程化命令,组成语言基本语句,编程时用户只需用这些命令说明“做什么”,不必描述实现细节; (3) 能满足多功能、一体化要求。为此,语言中除必须含有控制程序逻辑及实现数据库操作语句外,还应包括生成及处理报表、表格、图形,以及实现数据运算与分析统计功能各种语句,共同构成一个一体化语言,以适应多种应用开发需要。 第七章 习题参考答案 一.回答问题 1.软件测试基本任务? 软件测试是按照特定规则,发现软件错误过程;好测试方案是尽可能发现迄今尚未发现错误测试;成功测试方案是发
32、现迄今尚未发现错误测试; 2.测试及调试主要区别? (1) 测试从一个侧面证明程序员失败;调试证明程序员正确; (2) 测试从已知条件开始,使用预先定义程序,且有预知结果,不可预见仅是程序是否通过测试;调试从不可知内部条件开始,除统计性调试外,结果是不可预见; (3) 测试有计划并且要进行测试设计;调试不受时间约束; (4) 测试是发现错误、改正错误、重新测试过程;调试是一个推理过程; (5) 测试执行是有规程;调试执行要求程序员进行必要推理; (6) 测试由独立测试组在不了解软件设计件下完成;调试由了解详细设计程序员完成; (7) 大多数测试
33、执行与设计可由工具支持;调试用工具主要是调试器。 3.人工复审方式与作用? 人工复审方式:代码会审、走查与排练与办公桌检查; 人工复审作用:检查程序静态错误。 4.什么是黑盒测试?黑盒测试主要采用技术有哪些? 黑盒测试也称为功能测试,它着眼于程序外部特征,而不考虑程序内部逻辑结构。测试者把被测程序看成一个黑盒,不用关心程序内部结构。黑盒测试是在程序接口处进行测试,它只检查程序功能是否能按照规格说明书规定正常使用,程序是否能适当地接收输入数据产生正确输出信息,并且保持外部信息(如数据库或文件)完整性。 黑盒测试主要采用技术有:等价分类法、边沿值分析法、错误推测法与因果图等
34、技术。 5.什么是白盒测试?白盒测试主要采用技术有哪些? 测试者了解被测程序内部结构与处理过程,对程序所有逻辑路径进行测试,在不同点检查程序状态,确定实际状态及预期状态是否一致。 白盒测试主要采用技术有:路径测试技术与事务处理流程技术,对包含有大量逻辑判断或条件组合程序采用基于逻辑测试技术。 6.路径测试技术中几种主要覆盖含义?举例说明? 语句覆盖:至少执行程序中所有语句一次。 判定覆盖:使被测程序中每一个分支至少执行一次。故也称为分支覆盖。 条件覆盖:执行所有可能穿过程序控制路流程。 条件组合测试:设计足够测试用例,使每个判定中所有可能条件取值组合至少执行一
35、次。 (例略) 7.等价分类法测试技术采用一般方法?举例说明? (1) (1) 为每个等价类编号; (2) (2) 设计一个新测试方案,以尽可能多覆盖尚未被覆盖有效等价类,重复这一步骤,直到所有有效等价类被覆盖为止。 (3) (3) 设计一个新测试方案,使它覆盖一个尚未被覆盖无效等价类, 重复这一步骤,直到所有无效等价类被覆盖为止。 (例略) 8.软件测试一般步骤? 单元测试、子系统测试、系统测试、验收测试、平行测试。 9.比较集成试两种方式优劣? 非渐增式测试方式:分别测试模块,再把所有模块按设计要求放在一起组成所要程序。该方法编写测试软件工作量大
36、模块间接口错误发现得晚,错误定位较难诊断,总体测试有错误容易漏掉,测试时间相对较少,可以并行测试所有模块,能充分利用人力,加快工程进度。。 渐增式测试方式:把下一个要测试模块,同已经测试好那些模块结合起来进行测试。该方法利用已测试过模块作测试软件,开销小,较早发现模块间接口错误,错误定位往往与最近入模块相关,对已测试好模块可在新加入模块条件下受到新检验,测试更彻底,需要较多测试时间,不能并行测试。 总来说,渐增式测试方法比较好。 10.软件测试策略? (1) (1) 在任何情况下都应使用边界值分析方法。 (2) (2) 必要时用等价类划分法补充测试方案。 (3) (3)
37、 必要时再用错误推测法补充测试方案。 (4) (4) 对照程序逻辑,检查已设计出测试方案。 (5) (5) 根据对程序可靠性要求采用不同逻辑覆盖标准,再补充一些测试方案。 二.某电力公司有A、B、C、D共四类收费标准,并规定,居民用电每月200度以下按A类收费, 200度以上按B类收费。动力电以每月1万度为分界,非高峰用电不足1万度按B类收费,达到或超过1万度按C类收费。高峰用电不足1万度按C类收费,达到或超过1万度按D类收费。试用基于逻辑测试方法为它设计足够测试用例实现条件组合完全覆概。 规则号 1 2 3 4 5 6 居民 用电 200度以下 Y
38、 200度以上 Y 动力用电 非高峰 1万度以下 Y 1万度以上 Y 高峰 1万度以下 Y 1万度以上 Y 收费 标准 A类 ▲ B类 ▲ ▲ C类 ▲ ▲ D类 ▲ 测试用例 用电类型 输入数据 预期结果 居民 用电 90度/月 A 110度/月
39、 B 动力用电 非 高峰 8000度/月 B 12000度/月 C 高峰 9000度/月 C 11000度/月 D 三.如图显示某程序逻辑结构。 试为它设计足够测试用例,分别实现对程序判定覆概、条件覆概与条件组合覆概。 设计测试方案 覆盖种类 需满足条件 测试数据 期望结果 判定覆盖 A>1,B=0 A=2,B=0 执行S1 A>1,B¹0或 A£1,B=0或 A£1,B¹0 A=2,B=1或 A=1,B=0或 A=1,B=1 执行S2 条件覆盖 以下四种情况各出现一次 A>1 B=0
40、 A=2,B=0 执行S1 A£1 B¹0 A=1,B=1 执行S2 条件组合 覆盖 A>1,B=0 A=2,B=0 执行S1 A>1,B¹0 A=2,B=1 执行S2 A£1,B=0 A=1,B=0 执行S2 A£1,B¹0 A=1,B=1 执行S2 四.某城市 号码由三部分组成。它们名称与内容分别是: 地区码:空白或三位数字; 前 缀:非‘0’或‘1’三位数字; 后 缀:4位数字。 假定被测程序能接受一切符合上述规定 号码,拒绝所有不符合规定 号码。根据该程序规格说明,作等价类划
41、分,并设计测试方案。 1.划分等价类 输入条件 有效等价类 无效等价类 地区码 1.空白; 2.三位数; 1. 1. 有非数字字符;2.少于三位数字; 3.多于三位数字。 前 缀 3.从200到999之间三位 4.有非数字字符;5.起始位为‘0’; 6.起始位为‘1’; 7.少于三位数字; 8.多于三位数字。 后 缀 4.四位数字。 9.有非数字字符;10.少于四位数字; 11.多于四位数字。 设计测试方案 方案 内容 输 入 预期 输出 地区码 前缀 后缀 1 空白 200~999之间三位数字 四位数字 (
42、 )276-2345 有效 2 三位数字 四位数字 (635)805-9321 有效 3 有非数字字符 (20A)723-4567 无效 4 少于三位数字 (33 )234-5678 无效 5 多于三位数字 (5555)345-6789 无效 6 有非数字字符 (345)5A2-3456 无效 7 起始位为‘0’ (345)012-3456 无效 8 起始位为‘1’ (345)132-3456 无效 9 少于三位数字 (345) 92-345
43、6 无效 10 多于三位数字 (345)4562-3456 无效 11 有非数字字符 (345)342-3A56 无效 12 少于四位数字 (345)342- 356 无效 13 多于四位数字 (345)562-34567 无效 第八章 软件维护 习题答案 1.为什么说软件维护是不可避免? 因为软件开发过程中,一般很难检测到所有错误,其次软件在应用过程中需要随用户新要求或运行环境变化而进行软件修改或完成功能增删等,为了提高软件应用水平与使用寿命,软件维护是不可避免。 2.软件维护一般分为哪几类?
44、 改正性维护:满足用户对已开发产品性能及运行环境不断提高要求,进而达到延长软件寿命目。 适应性维护:对程序使用期间发现程序错误进行诊断与改正过程,配合变化了环境进行修改软件活动; 完善性维护:满足用户在使用过程中提出增加新功能或修改已有功能建议而进行工作; 预防性维护:为了改善未来可维护性或可靠性而修改软件工作。 3.影响软件维护因素有哪些? 开发方法:采用模块化详细设计文档有助于理解软件结构、界面功能与内部流程;开发过程中严格而科学管理规划及清晰可靠文档资料对发生错误后理解及纠错是至关重要;开发过程中模块独立程度越高,对软件修改越容易,对软件改进与移植越方便。
45、 开发条件:软件开发及维护人员水平决定了软件开发质量与维护效率;开发过程中使用标准程序设计语言与标准操作系统接口,可以大大提高软件可维护性;在测试过程中用例有效性,可极大地减少软件存在错误;其次使用规范化文档资料可为维护提供更好依据。 4.软件维护困难主要表现在什么方面? (1) 一般来讲,维护人员对开发人员写程序及文档,理解都比较困难,对维护工作不会喜欢; (2) 维护持续时间都很长,在开发人员不在现场轻快下,维护软件通常是很困难; (3) 绝大多数软件在设计时对将来软件修改都没有考虑或考虑不多,尤其未能在设计中强调并认真解决好模块独立性,使软件修改既困难又易发生差错
46、 5.决定软件可维护性因素? (1) 软件可理解性、可测试性、可修改性; (2) 文档描述符合要求、用户文档简洁明确、系统文档完整并且标准。 6.软件价格应该计入维护成本吗?为什么? 在软件生命周期中,软件维护工作量非常大,不同应用领域维护成本差别也很大。一般大型软件维护成本远远高于开发成本若干倍。因此软件价格中应该计入维护成本。 7.对前面各章中分析各应用系统,提出改进与扩充功能要求? (1) 教材销售采购系统; (2) 图书管理系统; (3) 房产管理系统。 (略) 第九章 软件工程管理 习题答案 1.软件工程管理内容? (1)
47、 费用管理: 对软件开发进行成本核算,使软件生产按照商品生产规律办事。包括:以简单、科学方法估算软件开发费用,作为签定开发合同根据;管理开发费用有效使用,即用经济手段来保证产品如期按质完成。 (2) 质量管理: 按项目质量保证计划,确保各个开发阶段开发与维护工作全部按软件工程规范进行,保证软件产品质量。 (3) 配置管理:通过对于程序、文档与数据各种版本所进行管理,保证资料完整性及一致性。 (4) 项目管理:制定《项目实施计划》,按照计划内容组织与实施软件工程化生产。最终目标是以合理费用与进度,圆满完成计划所规定软件项目。 2.软件项目有哪些特点? (1) 软件项目及
48、其他任何产业项目不同,它是算法、思想、概念、组织、流程、效率、优化等融合体; (2) 开发软件项目产品,在多数情况下,用户给不出明确想法与要求。 (3) 在开发过程中,程序及其相关文档资料常常需要修改,在修改过程中又可能带来新问题,且这些问题要在很久以后才会发现。 (4) 在研制开发过程中,文档资料是不可缺少,但工作量又是巨大,往往也是人们不愿去作。 (5) 参加软件项目工作人员,要求具有一定业务水平与实际工作经验,而很难完全避免人员流动,对工作影响是很大。离开人员不仅带走了重要信息,而且带走了工作经验。 3.软件成本估算一般方法? 自顶向下估计: 首先估算出项
49、目总开发成本,然后在项目内部进行成本分配。由少数专家参及,依靠他们过去经验,将要开发软件及过去开发过软件进行"类比",以估计新软件开发所需要工作量与成本。 自底向上估计: 将开发任务分成若干子任务,子任务又分成子子任务,直到每一个单元内容足够明确为止;把各个任务单元成本估计出来,汇合成项目总成本。该方法得到结果比较接近实际。 4.为什么在软件开发中,不能用简单增加人员方法来缩短开发时间? 大量软件开发实践说明:向一个已经延迟项目追加开发人员,可能使它完成得更晚。因为当开发人员以算术级数增长时,而人员之间通信将以几何级数增长,往往"得不偿失"。 5.影响软件质量主要因素有哪些?
50、 (1) 产品运行:正确性、风险性、效率、完整性、健壮性与可用性; (2) 产品修改:可理解性、可维护性、灵活性、可测试性; (3) 产品转移:可移植性、可重用性与互运行性。 6.本章第四节例子是某个软件项目PERT图。 (1)找出关键路径与完成项目最早时间; (2)标出每项活动最早起止时间及最迟起止时间。 (见该章教案举例) 7.将上题内容改用Gantt图来表示。 (见该章教案举例) 第十章 软件工程环境 习题答案 1.软件工具是什么?按照软件生存周期可将其分为几类? 软件工具是指为支持计算机软件及其文档开发、维护、模拟、移植或管理而






