软件工程习题.docx
《软件工程习题.docx》由会员分享,可在线阅读,更多相关《软件工程习题.docx(18页珍藏版)》请在冰豆网上搜索。
软件工程习题
软件工程复习重点难点
重点要求是以软件工程课程的教学大纲为依据,目的在于使学生理清思路,分清主次。
为本课程的期末复习提供参考。
一、 各章重点、难点和复习要求说明
第一章软件工程概述
1. 重点掌握的内容:
软件和软件工程的基本概念
软件:
软件定义由以下三部分组成:
(1) 在运行中能提供所希望的功能和性能的指令集(即程序);
(2) 使程序能够正确运行的数据结构;
(3) 描述程序研制过程、方法所用的文挡。
软件是一种产品,同时又是开发和运行产品的载体。
作为一种产品,它表达了由计算机硬件体现的计算潜能。
作为开发运行产品的载体,软件是计算机工作的基础、信息通信的基础,也是创建和控制其他程序的基础。
软件的特点:
①软件是一种逻辑实体,而不是具体的物理实体,因而它具有抽象性。
②软件是通过人们的智力活动,把知识与技术转化成信息的一种产品,是在研制、开发中被创造出来的。
③在软件的运行和使用期间,没有硬件那样的机械磨损、老化问题。
④软件的开发和运行经常受到计算机系统的限制,对计算机系统有着不同程度的依赖性。
⑤软件的开发至今尚未完全摆脱手工的开发方式。
⑥软件的开发费用越来越高,成本相当昂贵。
软件工程:
是指导计算机软件开发和维护的工程学科。
采用工程的概念、原理、技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够得到的最好的技术方法结合起来。
软件工程准则可以概括为七条基本原理:
(1)用分阶段的生存周期计划严格管理;
(2)坚持进行阶段评审;
(3)实行严格的产品控制;
(4)采用现代程序设计技术;
(5)结果应能清楚地审查结果;
(6)开发小组的人员应该少而精
(7)承认不断改进软件工程实践的必要性。
详细阐述见书中1.2.2节。
软件危机:
指的是软件开发和维护过程中遇到的一系列严重问题。
软件工程的基本内容:
软件工程学的内容可包括理论、结构、方法、工具、环境、管理、规范等。
第二章软件过程
1. 重点掌握的内容:
软件生存周期及软件开发的各种模型;
软件生存周期:
一个软件从定义到开发、使用和维护,直到最终被弃用,要经历一个漫长的时期,通常把软件经历的这个漫长的时期称为生存周期。
软件生存周期一般可分为以下阶段:
·问题定义
·需求分析与可行性研究
·设计
·编码
·测试
·运行与维护
软件开发模型:
软件开发模型是跨越整个软件生存周期的系统开发、运作、维护所实施的全部工作和任务的结构框架。
瀑布模型即生存周期模型,由B.M.Boehm提出,是软件工程的基础模型。
其核心思想是按工序将问题化简,将功能的实现与设计分开,便于分工协作。
采用结构化的分析与设计方法,将逻辑实现与物理实现分开。
此外,还有螺旋模型、第四代技术模型、原型模型、构件组装模型、混合模型等软件开发模型。
第三章需求分析
1.重点掌握的内容:
需求分析的方法和面向数据流的分析方法;。
需求分析的方法:
需求分析方法由对软件的数据域和功能域的系统分析过程及其表示方法组成,它定义了表示系统逻辑视图和物理视图的方式,大多数的需求分析方法是由数据驱动的,也就是说,这些方法提供了一种表示数据域的机制,分析员根据这种表示,确定软件功能及其他特性,最终建立一个待开发软件的抽象模型,即目标系统的逻辑模型。
面向数据流的需求分析方法:
结构化分析方法是面向数据流进行需求分析的方法。
结构化分析方法使用数据流图DFD与数据字典DD来描述,面向数据流问题的需求分析适合于数据处理类型软件的需求描述。
其核心思想是分解化简问题,将物理与逻辑表示分开,对系统进行数据与逻辑的抽象。
具体来说,结构化分析方法就是用抽象模型的概念,按照软件内部数据传递、变换的关系,自顶向下逐层分解,直到找到满足功能要求的所有可实现的软件为止。
重点掌握结合实例画数据流图和定义数据字典。
系统流程图:
系统流程图是描绘物理系统的传统工具。
它的基本思想是用图形符号以黑盒子形式描绘系统里面的每个部件(程序,文件,数据库,表格,人工过程等等)。
系统流程图表达的是部件的信息流程,而不表示对信息进行加工处理的控制过程。
详见2.3节。
系统流程图的功能:
1.制作系统流程图的过程是系统分析员全面了解系统业务处理概况的过程,它是系统分析员作进一步分析的依据。
2.系统流程图是系统分析员、管理人员、业务操作人员相互交流的工具。
3.系统分析员可直接利用系统流程图画出可以实现计算机处理的部分。
4.可利用系统流程图来分析业务流程的合理性。
2.一般掌握的内容:
需求分析的任务和原则。
.
需求分析的任务:
它的基本任务是准确地回答“系统必须做什么?
”这个问题。
需求分析所要做的工作是深入描述软件的功能和性能,确定软件设计的限制和软件同其它系统元素的接口细节,定义软件的其它有效性需求。
需求分析的任务不是确定系统如何完成它的工作,而是确定系统必须完成哪些工作,也就是对目标系统提出完整、准确、清晰、具体的要求。
其实现步骤如下图所示:
模型化抽象化理解需求
怎么做做什么
具体化实例化
表达需求
一般说来,需求分析阶段的任务包括下述几方面:
①确定对系统的综合需求
对系统的综合需求主要有:
系统功能需求、系统性能需求、运行需求、将来可能提出的需求。
②分析系统的数据需求
③导出系统的逻辑模型
就是在理解当前系统“怎样做”的基础上,抽取其“做什么”的本质,明确目标系统要“做什么”,可以导出系统的详细的逻辑模型。
具体做法是:
首先确定目标系统与当前系统的逻辑差别;然后将变化部分看作是新的处理步骤,对功能图(一般为数据流图)及对象图进行调整;最后由外及里对变化的部分进行分析,推断其结构,获得目标系统的逻辑模型。
通常用数据流图、数据字典和主要的处理算法描述这个逻辑模型。
④修正系统开发计划
在经过需求分析阶段的工作,分析员对目标系统有了更深入更具体的认识,因此可以对系统的成本和进度做出更准确的估计,在此基础上应该对开发计划进行修正。
⑤开发原型系统
使用原型系统的主要目的是,使用户通过实践获得关于未来的系统将怎样为他们工作的更直接更具体的概念,从而可以更准确地提出和确定他们的要求。
需求分析的步骤:
1.调查研究;2.分析与综合;3.书写文档;4.需求分析评审
需求分析的原则:
其基本原则可概括为:
(1)必须能够表达和理解问题的数据域和功能域;
(2)按自顶向下、逐层分解问题;(3)要给出系统的逻辑视图和物理视图;
2. 可行性研究的任务和步骤,成本效益分析
可行性研究的任务:
是用最小的代价在尽可能短的时间内确定问题是否能够解决。
一般说来,应从经济可行性、技术可行性、运行可行性、法律可行性和开发方案等方面研究可行性。
可行性研究的步骤:
可行性研究的步骤分为九个步骤。
成本效益分析:
成本/效益分析的目的是要从经济角度分析开发一个特定的新系统是否可行,从而帮助使用部门负责人正确地做出是否投资于这项开发工程的决定。
几种度量效益的方法:
1.货币的时间价值;2.投资回收期;3.纯收入。
第四章结构化设计
1. 重点掌握的内容:
结构化设计的过程和方法
概要设计任务:
①系统分析员审查软件计划、软件需求分析提供的文档,提出最佳推荐方案,用系统流程图,组成系统物理元素清单,成本效益分析,系统的进度计划,供专家审定,审定后进入设计。
②确定模块结构,划分功能模块,将软件功能需求分配给所划分的最小单元模块。
确定模块间的联系,确定数据结构、文件结构、数据库模式,确定测试方法与策略。
③编写概要设计说明书,用户手册,测试计划,选用相关的软件工具来描述软件结构,结构图是经常使用的软件描述工具。
选择分解功能与划分模块的设计原则,例如模块划分独立性原则,信息隐蔽原则等。
概要设计过程:
概要设计要先进行系统设计,复审系统计划与需求分析,确定系统具体的实施方案;然后进行结构设计,确定软件结构。
软件设计的概念与原则:
①将软件划分成若干独立成分的依据。
②如何表示不同的成分内的功能细节和数据结构。
③如何统一衡量软件设计的技术质量。
其中有几个概念:
1.模块化:
就是把程序划分成若干个模块,每个模块具有一个子功能,把这些模块集总起来组成一个整体,可以完成指定的功能,实现问题的要求。
2.抽象:
就是抽出事物的本质特性而暂时不考虑它们的细节。
3.信息隐蔽:
模块中所包括的信息不允许其它不需要这些信息的模块调用。
4.信息局部化:
是指把一些关系密切的软件元素物理地放得彼此靠近。
5.模块独立性:
是软件系统中每个模块只涉及软件要求的具体子功能,而和软件系统中其他的模块接口是简单的。
模块独立的概念是模块化、抽象、信息隐蔽和局部化概念的直接结果。
6.耦合:
是对一个软件结构内各个模块之间互连程度的度量。
耦合强弱取决于模块间接口的复杂程度,调用模块的方式,以及通过接口的信息。
7.内聚:
标志一个模块内各个元素彼此结合的紧密程度,它是信息隐蔽和局部化概念的自然扩展。
概要设计的方法:
面向数据流的设计方法把信息流映射成软件结构,信息流的类型决定了映射的方法。
面向数据流的设计要解决的任务,就是上述需求分析的基础上,将DFD图映射为软件系统的结构。
换句话说,这类设计方法允许把用DFD图表示的系统逻辑模型方便地转换成对于软件结构的初始设计描述。
理解基本概念:
信息流(包括变换流和事务流)、抽象与逐步求精;模块化与信息隐藏;软件总体结构、数据结构与软件过程。
面向数据结构的分析设计方法:
①Jackson系统开发方法(JSD):
Jackson系统开发方法(JSD,JacksonSystemDevelopment)是一种典型的面向数据结构的分析设计方法,它是以信息驱动的,是将信息转换成软件的程序结构。
②Warnier方法:
Warnier程序设计方法是由法国人J.D.Warnier提出的另一种面向数据结构的设计方法,又称为逻辑构造程序的方法,简称LCP(LogicalConstructionofPrograms)方法。
Warnier方法的原理和Jackson方法类似,也是从数据结构出发设计程序,但是这种方法的逻辑更严格。
2. 一般掌握的内容:
概要设计的文档与评审
学会撰写概要设计的文档并能评审出概要设计文档是否符合要求。
概要设计说明书的主要内容及结构详见4.5节。
详细设计
1. 重点掌握的内容:
详细设计的任务和方法
详细设计的任务:
详细设计就是要在概要设计的结果的基础上,考虑“怎样实现”这个软件系统,直到对系统中的每个模块给出足够详细的过程性描述。
主要任务如下:
①为每个模块确定采用的算法,选择某种适当的工具表达算法的过程,写出模块的详细过程性描述;②确定每一模块使用的数据结构;③确定模块接口的细节,包括对系统外部的接口和用户界面,对系统内部其它模块的接口,以及模块输入数据、输出数据及局部数据的全部细节。
④要为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定的测试,模块的测试用例是软件测试计划的重要组成部分,通常应包括输入数据,期望输出等内容。
详细设计的方法:
程序流程图、N-S图、PAD图、HIPO图
程序流程图:
程序流程图又称之为程序框图,它是软件开发者最熟悉的一种算法表达工具。
它独立于任何一种程序设计语言,比较直观和清晰地描述过程的控制流程,易于学习掌握。
在流程图中只能使用下述的五种基本控制结构。
①顺序型;②选择型;③while型循环;④until型循环;⑤多情况型选择。
详见5.2.1节。
N-S图:
Nassi和Shneiderman提出了一种符合结构化程序设计原则的图形描述工具,称为盒图,又称为N-S图。
在N-S图中,为了表示五种基本控制结构,规定了五种图形构件。
①顺序型;②选择型;③WHILE重复型;④UNTIL重复型;⑤多分支选择型。
PAD图:
它是用结构化程序设计思想表现程序逻辑结构的图形工具。
PAD也设置了五种基本控制结构的图示,并允许递归使用。
详见5.2.3节。
HIPO图:
HIPO图是由一组IPO图加一张HC图组成。
它是美国IBM公司在软件设计中使用的主要表达工具。
HC图是层次图(Hierarchychart)的英文缩写,用于表示软件的分层结构。
HC图中的每一个模块,均可用一张IPO图来描述。
IPO图由输入、处理和输出三个框组成,需要时还可以增加一个数据文件框,这种图形的优点,是能够直观地显示输入—处理—输出三者之间的联系。
2. 一般掌握的内容:
详细设计的原则及详细设计规格与评审
详细设计的原则:
原则是过程描述是否易于理解、复审和维护,进而过程描述能够自然地转换成代码,并保证详细设计与代码完全一致。
详细设计规格与评审:
详细设计说明书的框架及评审
第5章结构化实现
1. 重点掌握的内容:
程序设计语言的特点、编程风格、程序效率和编程安全;结构化的软件测试
程序设计语言的特点:
程序设计语言是人与计算机交流的媒介。
软件工程师应该了解程序设计语言各方面的特点,以及这些特点对软件质量的影响,以便在需要为一个特定的开发项目选择语言时,能作出合理的技术抉择。
其特点表现为九个方面:
①名字说明;②类型说明;③初始化;④程序对象的局部性;⑤程序模块;⑥循环控制结构;⑦分支控制结构;⑧异常处理;⑨独立编译。
编程风格:
编码风格又称程序设计风格或编程风格,实际上指编程的原则。
表现为四个方面:
源程序文档化,数据说明的方法,语句结构和输入/输出方法。
源程序文档化:
源程序文档化又可从四个方面来阐述,①符号名的命名;②程序的注释;③标准的书写格式;
数据说明:
数据说明的次序应当规范化。
使数据属性容易查找,也有利于测试,排错和维护。
语句结构:
语句构造力求简单、直接,不能为了片面追求效率而使语句复杂化。
可从以下几方面注意:
1.使用标准的控制结构;2.尽可能使用库函数;3.程序编写首先应当考虑清晰性;4.注意使用GOTO语句;
输入/输出方法:
输入/输出的方式和格式应当尽量作到对用户友善(UserFriendly),尽可能方便用户的使用。
程序效率:
程序效率是指程序的执行速度及程序占用的存储空间。
影响程序效率的因素是多方面的,
编程安全:
提高软件质量和可靠性的技术大致可分为两类,一类是避开错误技术,即在开发的过程中不让差错潜入软件的技术;另一类是容错技术,即对某些无法避开的差错,使其影响减至最小的技术;避开错误技术是进行质量管理,实现产品应有质量所必不可少的技术,也就是软件工程中所讨论的先进的软件分析和开发技术和管理技术。
但是,无论使用多么高明的避开错误技术,也无法做到完美无缺和绝无错误,这就需要采用容错技术。
实现容错的主要手段是冗余和防错程序设计。
结构化的软件测试:
软件测试在程序员对每一个模块的编码之后先做程序测试,再做单元测试,然后再进行集成(综合或组装)测试,系统测试,验收(确认)测试,平行测试,人工测试,其中单元测试的一部分己在编码阶段就开始了。
测试:
就是用已知的输入在已知环境中动态地执行系统(或系统的“部件”)。
如果测试结果和预期结果不一致,则很可能是发现了系统中的错误。
软件测试:
软件测试是对软件计划、软件设计、软件编码进行查错和纠错的活动(包括代码执行活动与人工活动)。
程序测试:
是对编码阶段的语法错、语义错、运行错进行查找的代码执行活动。
找出编码中错误的代码执行活动称程序测试。
纠正编码中的错误的执行活动称程序调试。
程序测试的目的是查找编码错与纠正编码错,保证算法的正确实现。
测试的原则:
(1)测试前要认定被测试软件有错,不要认为软件没有错。
(2)要预先确定被测试软件的测试结果。
(3)要尽量避免测试自己编写的程序。
(4)测试要兼顾合理输入与不合理输入数据。
(5)测试要以软件需求规格说明书为标准。
(6)要明确找到的新错与已找到的旧错成正比。
(7)测试是相对的,不能穷尽所有的测试,要据人力物力安排测试,并选择好测试用例与测试方法。
(8)测试用例留作测试报告与以后的反复测试用,重新验证纠错的程序是否有错。
测试方法:
按照测试过程是否在实际应用环境中来分,有静态分析与动态测试。
测试方法有分析方法(包括静态分析法与白盒法)与非分析方法(称黑盒法)。
静态分析技术:
不执行被测软件,可对需求分析说明书、软件设计说明书、源程序做结构检查、流程分析、符号执行来找出软件错误。
动态测试技术:
当把程序作为一个函数,输入的全体称为函数的定义域,输出的全体称为函数的值域,函数则描述了输入的定义域与输出值域的关系。
这样动态测试的算法可归纳为:
①选取定义域中的有效值,或定义域外无效值。
②对已选取值决定预期的结果。
③用选取值执行程序。
④观察程序行为,记录执行结果。
⑤将④的结果与②的结果相比较,不吻合则程序有错。
动态测试既可以采用白盒法对模块进行逻辑结构的测试,又可以用黑盒法做功能结枸的测试、接口的测试,都是以执行程序并分析执行结果来查错的。
白盒法:
是通过分析程序内部的逻辑与执行路线来设计测试用例,进行测试的方法,白盒法也称逻辑驱动方法。
白盒法的具体设计程序测试用例的方法有:
语句覆盖、分支(判定)覆盖、条件覆盖、路径覆盖(或条件组合覆盖),主要目的是提高测试的覆盖率。
黑盒法:
是功能驱动方法,仅根据I/O数据条件来设计测试用例,而不管程序的内部结构与路径如何。
黑盒法的具体设计程序测试用例的方法有:
等价类划分法,边界值分析法,错误推测法,主要目的是设法以最少测试数据子集来尽可能多的测试软件程序的错误。
设计测试方案:
测试方案包括预定要测试的功能,应该输入的测试数据和预期的结果,其中最困难的问题是设计测试用的输入数据(即测试用例)。
通常的做法是,用黑盒法设计基本的测试方案,再用白盒法补充一些方案。
详见8.7.2节中的例子。
软件测试的步骤:
软件测试的步骤详见8.7.3节中的图8-8测试步骤。
单元测试:
单元测试也称模块测试、逻辑测试、结构测试,测试的方法一般采用白盒法,以路径覆盖为最佳测试准则。
集成测试:
单元测试之后便进入组装测试。
尽管模拟了驱动模块和存根模块进行单元测试,由于测试不能穷尽,单元测试又会引入新错误,单元测试后肯定会有隐藏错误,组装不可能一次成功,必须经测试后才能成功。
集成测试分为增式组装测试和非增式组装测试,所谓非增式组装,按照结构图一次性将各单元模块组装起来。
所谓增式组装是指按照结构图自顶向下或自底向上逐渐安装。
确认测试:
确认测试也称合格测试或称验收测试。
组装后己成为完整的软件包,消除了接口的错误。
确认测试主要由使用用户参加测试,检验软件规格说明的技术标准的符合程度,是保证软件质量的最后关键环节。
系统测试:
一般的系统除了确认测试外还要做如下几个方面的系统测试
①恢复测试
通过系统的修复能力,检测重新初始化,数据恢复,重新启动,检验点设置机构是否正确,以及人工干预的平均恢复时间是否在允许范围内。
②安全测试
设计测试用例,突破软件安全保护的机构安全保密措施,检验系统是否安全保密的漏洞。
③强度测试
设计测试用例,检验系统的能力最高能达到什么实际的限度,让系统处于资源的异常数量、异常频率、异常批量的条件下运行测试系统的承受能力。
一般取比平常限度高5一10倍的限度做测试用例。
④性能测试
设计测试用例测试并记录软件运行性能,与性能要求比较,看是否达到性能要求规格。
这项测试常常与强度测试相结合进行。
1. 一般掌握内容:
软件维护过程
软件维护:
软件运行/维护阶段对软件产品所进行的修改就是维护。
维护的问题:
软件维护存在的绝大多数问题,都是由于软件定义和软件开发的方法有问题。
在软件生命周期的头两个时期没有严格而又科学的管理和规划,几乎必然会导致在最后阶段出现问题。
软件维护步骤及组织:
为了正确、有效地修改,需要经历以下三个步骤:
1.分析和理解程序;2.修改程序;3.重新验证程序;4.维护组织。
第六章面向对象的分析和设计方法
1.重点掌握的内容:
面向对象的基本概念和特征
面向对象的基本概念:
面向对象不仅是一些具体的软件开发技术与策略,而且是一整套关于如何看待软件系统与现实世界的关系,以什么观点来研究问题并进行求解,以及如何进行系统构造的软件方法学。
而面向对象方法是一种运用对象、类、继承、封装、聚合、消息传送、多态性等概念来构造系统的软件开发方法。
面向对象方法的基本思想是,从现实世界中客观存在的事物(即对象)出发来构造软件系统,并在系统构造中尽可能运用人类的自然思维方式。
面向对象的几个重要概念:
对象、消息、方法性、继承性、封装性等。
详见6.1.3节。
面向对象方法的基本特征:
①从问题域中客观存在的事物出发来构造软件系统,用对象作为对这些事物的抽象表示,并以此作为系统的基本构成单位。
②事物的静态特征(即可以用一些数据来表达的特征)用对象的属性表示,事物的动态特征(即事物的行为)用对象的服务(或操作)表示。
③对象的属性与服务结合为一体,成为一个独立的实体,对外屏蔽其内部细节(称作封装)。
④对事物进行分类。
把具有相同属性和相同服务的对象归为一类,类是这些对象的抽象描述,每个对象是它的类的一个实例。
⑤通过在不同程度上运用抽象的原则(较多或较少地忽略事物之间的差异),可以得到较一般的类和较特殊的类。
特殊类继承一般类的属性与服务,面向对象方法支持对这种继承关系的描述与实现,从而简化系统的构造过程及其文档。
⑥复杂的对象可以用简单的对象作为其构成部分,称作聚合。
⑦对象之间通过消息进行通信,以实现对象之间的动态联系。
⑧通过关联表达对象之间的静态关系。
3.一般掌握的内容:
面向对象分析与设计方法面向对象程序设计步骤
面向对象分析方法:
目前出现有OOA与OOD方法。
面向对象设计方法:
OOA与OOD的职责划分是:
OOA针对问题域运用OO方法,建立一个反映问题域的OOA模型,不考虑与系统的具体实现有关的因素(例如采用什么编程语言、图形用户界面、数据库等等),从而使OOA模型独立于具体的实现。
OOD则是针对系统的一个具体的实现运用OO方法。
其中包括两方面的工作,一是把OOA模型直接搬到OOD(不经过转换,仅作某些必要的修改和调整),作为OOD的一个部分;二是针对具体实现中的人机界面、数据存储、任务管理等因素补充一些与实现有关的部分。
这些部分与OOA采用相同的表示法和模型结构。
二、 考试题型
笔试题型和解题基本要求
考试题型可以有选择、填空、判断、简答题、建模题等。
选择、填空题、判断、简答题主要考核学生对基本概念的理解和掌握程度。
建模题主要考核学生对所学知识的应用能力。
例如:
选择:
1.一个成功的测试可以( )。
A、表明程序没有错误 B、发现所有错误
C、提高软件可靠性 D、发现尚未发现的错误
2.黑盒技术设计测试用例的方法之一为( )。
A、条件组合覆盖 B、逻辑覆盖
C、等价类划分 D、基本路径测试
3.软件详细设计的主要任务是对( )进行的详细设计。
A、算法和数据结构 B、外部接口
C、软件编码 D、功能软件维护的副作用,是指( )。
4.在考查系统的一些涉及时序和改变的状况时,要用动态模型来表示。
动态模型着重于系统的控制逻辑,它包括两个图:
一个是事件跟踪图,另一个是()。
A、数据流图B、状态图
C、系统结构图D、时序图
5.Jackson方法是一种面向( )的方法。
A、数据流 B、对象
C、数据结构 D、控制流
6.关联是建立( )之间关系的一种手段。
A、类 B、对象