安徽大学软件工程复习题集Word格式.docx
- 文档编号:22077400
- 上传时间:2023-02-02
- 格式:DOCX
- 页数:28
- 大小:479.04KB
安徽大学软件工程复习题集Word格式.docx
《安徽大学软件工程复习题集Word格式.docx》由会员分享,可在线阅读,更多相关《安徽大学软件工程复习题集Word格式.docx(28页珍藏版)》请在冰豆网上搜索。
A.使用这种软件过程开发出的软件产品通常能满足用户的真实需求;
B.软件产品的开发过程基本上是线性顺序过程。
③增量模型
增量模型也称为渐增模型
增量模型的主要优点:
A.能在较短时间向用户提交可完成部分工作的产品;
B.逐步增加产品功能,从而使用户有较充裕的时间学习和适应新产品,减少一个全新的软件给客户组织带来的冲击。
④螺旋模型
螺旋模型的基本思想是,使用原型及其他方法尽量降低风险。
理解这种模型的一个简便方法,是把它看作在每个阶段之前都增加了风险分析过程的快速原型模型。
螺旋模型所描述的软件过程主要适用于部开发的大型软件项目。
使用螺旋模型开发软件,要求软件开发人员具有丰富的风险评估知识和经验。
螺旋模型主要有下述优点:
A.有利于已有软件的重用;
B.有助于把软件质量作为软件开发的一个重要目标;
C.减少了过多测试或测试不足所带来的风险;
D.软件维护与软件开发没有本质区别。
⑤喷泉模型
迭代是软件开发过程中普遍存在的一种在属性。
在面向对象型中,软件开发过程各阶段之间的迭代或同一阶段各个工作步骤之间的迭代,比在结构化型中更常见。
喷泉模型,是典型的面向对象生命周期模型,它充分体现了面向对象软件开发过程迭代和平滑过渡的特性。
5、1.软件生命周期概念
软件产品从提出、实现、使用维护到停止使用退役的过程称为软件生命周期。
软件生命周期分为3个时期共8个阶段,
软件定义期:
包括问题定义、可行性研究和需求分析3个阶段;
软件开发期:
包括概要设计、详细设计、实现和测试4个阶段;
运行维护期:
即运行维护阶段。
表3-3软件生命周期各阶段的主要任务
任务
描述
问题定义
确定要求解决的问题是什么
可行性研究与计划制定
决定该问题是否存在一个可行的解决办法,指定完成开发任务的实施计划
需求分析
对待开发软件提出需求进行分析并给出详细定义。
编写软件规格说明书及初步的用户手册,提交评审
软件设计
通常又分为概要设计和详细设计两个阶段,给出软件的结构、模块的划分、功能的分配以及处理流程。
这阶段提交评审的文档有概要设计说明书、详细设计说明书和测试计划初稿
软件实现
在软件设计的基础上编写程序。
这阶段完成的文档有用户手册、操作手册等面向用户的文档,以及为下一步作准备而编写的单元测试计划
软件测试
在设计测试用例的基础上,检验软件的各个组成部分。
编写测试分析报告
运行维护
将已交付的软件投入运行,同时不断的维护,进行必要而且可行的扩充和删改
第2章可行性研究
1、可行性研究包括哪几方面(每方面解决什么问题),研究得到的文档和结论是什么?
技术可靠性:
使用现有的技术能否实现这个系统吗?
经济可行性:
这个系统的经济效益能否超过它的开发成本?
操作可行性:
系统的操作方式在这个用户组织是否行得通?
研究的结果:
是一份可行性研究的各个步骤的工作结果的文档,它包含了工程是否能继续进行下去和分析员的推荐方案;
2、主要描述工具的概念和使用:
系统流程图:
是什么,成份和基本符号,描述什么模型,画法;
数据流图:
是什么,成份和基本符号,系统级和功能级、简单细化数据流图的区别,画法;
数据字典:
是什么,容、定义数据的方法。
(1)系统流程图的定义:
是概括地描绘物理系统的传统工具。
它用图形符号以黑盒子形式描绘组成系统的每个部件。
系统流程图表达的是数据在系统各部件之间流动的情况,而不是对数据进行加工处理的控制过程,是物理数据流图而不是程序流程图。
系统流程图的基本符号:
(2)数据流图的定义:
它是一种图形化技术,它描述信息和数据从输入移动到输出过程中所经历的变换。
在数据流图中没有任何具体的物理部件,它只是描绘数据在软件中流动和被处理的逻辑过程。
数据流图的基本符号:
正方形(或立方体)表示数据的源点或终点;
圆角矩形(或圆形)代表变换数据的处理;
开口矩形(或两条平行横线)代表数据存储;
箭头线表示数据流,即特定数据的流动方向。
(3)数据字典的定义:
是关于数据的信息的集合,也就是对数据流图中包含的所有元素的定义的集合。
数据字典的作用也正是在软件分析和设计的过程中给人提供关于数据的描述信息。
数据字典的容:
数据流、数据流分量、数据存储、处理
定义数据的方法:
用被定义的事物的成分的某种组合表示这个事物,这些组成成分又由更低的成分组合来定义。
3、数据字典和数据流图的关系。
数据流图和数据字典共同构成系统的逻辑模型。
没有数据字典,数据流图就不严格,然而没有数据流图,数据字典也难于发挥作用。
只有数据流图和对数据流图中每个元素的精确定义放在一起,才能共同构成系统的规格说明。
第3章需求分析
需求规格说明书
1、需求分析的任务是什么?
分析得到的成果(文档)是什么?
包含哪些容?
1、需求分析的任务:
(1)确定对系统的综合要求:
功能需求、性能需求、可靠性和可用性需求、出错处理需求、接口需求、约束、逆向需求、将来可能提出的要求
(2)分析系统的数据要求:
(3)导出系统的逻辑模型(4)修正系统开发计划;
2、需求分析得到的结果:
是通过需求分析得到的除了分析模型之外,还应该写出软件需求规格说明书,它是需求分析阶段得出的最主要的文档。
2、软件需求通常包括哪些方面?
各类需求一般包含容有哪些?
(1)功能需求:
这方面的需求指定系统必须提供的服务。
通过需求分析应该划分出系统必须完成的所有功能。
(2)性能需求:
性能需求指定系统必须满足的定时约束或容量约束,通常包括速度(响应时间)、信息量速率、主存容量、磁盘容量、安全性等方面的需求。
(3)可靠性和可用性需求:
可靠性需求定量地指定系统的可靠性。
可用性与可靠性密切相关,它量化了用户可以使用系统的程度。
(4)出错处理需求:
这类需求说明系统对环境错误应该怎样响应。
(5)接口需求:
接口需求描述应用系统与它的环境通信的格式。
常见的接口需求有:
用户接口需求;
硬件接口需求;
软件接口需求;
通信接口需求。
(6)约束:
设计约束或实现约束描述在设计或实现应用系统时应遵守的限制条件。
(7)逆向需求:
逆向需求说明软件系统不应该做什么。
(8)将来可能提出的要求:
应该明确地列出那些虽然不属于当前系统开发畴,但是据分析将来很可能会提出来的要求。
这样做的目的是,在设计过程中对系统将来可能的扩充和修改预做准备,以便一旦确实需要时能比较容易地进行这种扩充和修改。
3、追加的主要描述工具的概念和使用:
E-R图:
是什么,成份和基本符号,描述什么模型;
状态转换图:
是什么,描述什么模型
(1)E-R图的定义:
即实体--联系图,是表示数据对象及其之间关系的图形语言机制,是建立数据模型的图形工具。
E-R图的基本成份和使用的符号:
实体(即数据对象)----矩形框,关系----菱形框,
属性----椭圆形或圆角矩形。
E-R图描述的模型:
用来建立数据模型,ER模型使用简单的图形符号表达系统分析员对问题域的理解
(2)状态转换图的定义:
通过描绘系统的状态及引起系统状态转换的事件,来表示系统的行为。
状态转换图的基本成份和使用的符号:
基本成分是状态、事件、状态转换。
状态转换图描述的模型:
用来建立系统的行为模型。
4、在结构化分析中,建模的核心是什么?
3种模型分别是什么,分别用什么工具来描述?
建模的核心是数据字典,它描述了所有的在目标系统中使用的和生成的数据对象。
(1)、数据模型,用实体-联系图描述;
(2)、功能模型,用数据流图描述;
(3)、行为模型,用状态转换图描述。
第5章总体设计
1、什么是总体设计?
将软件需求转化为软件的数据结构和系统结构,确定各组成成分(子系统或模块)之间的相互关系
2、模块化设计的原理包括什么?
为了提高软件的可维护性,其中,模块独立性最重要的,是评价软件结构质量的首要标准。
模块化设计的原理包括:
模块化、抽象、逐步求精、信息隐藏和局部化、模块独立。
3、模块独立性度量(描述)的两个指标:
聚、耦合;
什么是聚,什么是耦合;
耦合和聚的具体分类及使用原则;
在面向数据流的方法中,聚、耦合各分为哪几级,每级的具体含义分别是什么?
强度从弱到强如何排列?
耦合和聚两者关系?
(1)耦合定义:
它是对一个软件结构不同模块之间互连程度的度量;
耦合分类:
耦合使用原则:
尽量使用数据耦合,小用控制耦合和特征耦合,限制公共环境耦合的围,完全不用容耦合,最终降低模块间接口的复杂性。
(2)聚定义:
它标志着一个模块各个元素彼此结合的紧密程度,它是信息隐藏和局部化概念的自然扩展。
聚分类:
聚使用原则:
设计时力求高聚,设计时应该力求做到高聚,通常中等程度的聚也是可以采用的,而且效果和高聚相差不多;
但是,低聚很坏,不要使用。
(3)耦合和聚两者关系:
耦合与聚都是模块独立性的定性标准,都反映模块独立性的良好程度。
其中聚更重要。
聚与耦合密切相关。
同其它模块强耦合的模块意味着它自己是弱聚的;
强聚模块意味着与其它模块间松散耦合。
所以设计的目标应该是力争高聚、低耦合。
第6章详细设计
1结构化程序设计
1结构化程序设计的原则
结构化程序设计方法的主要原则可以概括为自顶向下,逐步求精,模块化,限制使用goto语句。
2结构化程序的基本结构与特点
1.顺序结构
2.选择结构:
选择结构又称为分支结构。
3.重复结构:
重复结构又称为循环结构。
2、什么是过程设计的工具?
分类?
基本要求?
过程设计工具的定义:
描述程序处理过程的工具
过程设计工具的分类:
它们可以分为图形、表格、和语言3类。
过程设计工具的基本要求:
不论是哪类工具,对它们的基本要求都是能提供对设计的无歧义的描述。
3、软件详细设计描述工具的概念和使用:
程序流程图、N-S图、PAD图、PDL语言:
是什么,基本符号和表示的意义,画法;
各种工具描述结果间的转换。
(1)程序流程图的定义:
又称为程序框图,它是历史最悠久、使用最广泛的描述过程设计的方法,然而它也是用得最混乱的一种方法。
程序流程图的基本符号:
(2)盒图(N-S图)的定义:
出于要有一种不允许违背结构程序设计精神的图形工具的考虑,Nassi和Shneiderman提出了盒图。
它有下述特点:
(1)功能域(即,一个特定控制结构的作用域)明确,可以从盒图上一眼就看出来。
(2)没有箭头,不可能任意转移控制。
(3)很容易确定局部和全程数据的作用域。
(4)很容易表现嵌套关系,也可以表示模块的层次结构。
盒图(N-S图)的基本符号:
(a)顺序;
(b)IF_THEB_ELSE型分支;
(c)CASE型多分支;
(d)循环;
(e)调用子程序
(3)PAD(问题分析图)的定义:
1973年由日本日立公司发明。
它用二维树形结构的图来表示程序的控制流,将这种图翻译成程序代码比较容易。
PAD(问题分析图)的基本符号:
(b)选择(IFCTHENP1ELSEP2);
(d)WHILE型循环(WHILECDOP);
(e)UNTIL型循环(REPEATPUNTILC);
(f)语句标号;
(g)定义
(3)过程设计语言(PDL)的定义:
也称为伪码,PDL是一种“混杂”语言,它使用一种语言的词汇,同时却使用另一种语言(某种结构化的程序设计语言)的语法。
过程设计语言(PDL)的举例:
第7章实现
1、软件测试的目的是什么?
软件测试方法的种类?
为了发现程序中的错误而执行程序的过程,测试阶段的根本目标是尽可能多地发现并排除软件中潜藏的错误,最终把一个高质量的软件系统交给用户使用。
2、软件测试与软件开发阶段的关系?
软件开发过程是一个自顶向下、逐步细化的过程,而测试则是依相反的顺序安排的,自底向上、逐步集成的过程。
低一级为上一级测试准备条件。
3、软件测试的步骤,过程。
模块测试----单元、子系统测试----局部、系统测试----全局、验收测试----用户参与、平行运行----新旧共存
4、软件测试的三大阶段:
单元测试、集成测试(组装测试)、确认测试(验收测试)的主要任务(目的)是什么?
测试的容主要有哪些?
测试计划分别在什么时候制定?
测试计划的容有哪些?
模块测试(单元测试)
目的:
是保证每个模块作为一个单元能正确运行。
在编写出源程序代码并通过了编译程序的语法检查之后,就可以用详细设计描述作指南,对重要的执行通路进行测试,以便发现模块部的错误。
容:
1.模块接口测试----检测数据能否正确无误地进入和流出模块
2.路径测试
3.出错处理测试----测试程序中包含的出错处理是否有效
4.边界条件测试----检测在数据边界处,模块能否正常工作
单元测试计划的时间:
在详细设计结束时制定,主要使用白盒测试技术
集成测试
任务:
在单元测试的基础上,需要将所有模块按照设计要求组装成为系统,发现并排除在模块连接的接口中可能出现的问题,最终构成所要求的软件系统。
(1)把各个模块连接起来后,考察穿越模块接口的数据是否会丢失或产生错误
(2)各个子功能组合起来,能否达到预期要求的主要功能
(3)一个模块的功能是否会对另一个模块的功能产生不利的影响
(4)全局数据结构是否有错误
(5)单个模块的误差累积起来,是否会被放大,从而达到不能被接受的程度
集成测试计划的时间:
在总体设计结束时制定,详细设计结束时补充
确认测试
也称为称验收测试。
它的主要目标是验证软件的有效性。
证实软件功能与用户需否一致,即测试软件能否按照软件需求规格说明书(合同)的要求运行。
有效性测试、软件配置复查、验收测试
确认测试计划的时间:
在需求分析时制定,后续阶段补充,通过黑盒测试技术。
5、什么是白盒测试?
典型的白盒测试技术有哪几个,含义如何?
简单的逻辑覆盖测试用例设计。
白盒测试的定义:
也称结构测试或逻辑驱动测试,它是按照程序部的结构测试程序,通过测试来检测产品部动作是否按照设计规格说明书的规定正常进行,检验程序中的每条通路是否都能按预定要求正确工作。
应用时间:
白盒测试在测试过程的早期阶段进行
白盒测试技术:
1、逻辑覆盖:
语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖、点覆盖、边覆盖、路径覆盖;
2、控制结构测试:
基本路径测试、条件测试、循环测试。
逻辑覆盖测试的5种标准
发现错误的能力
标准
含义
1(弱)
语句覆盖
每条语句至少执行一次A=2,B=0,X=4
2
判定覆盖
每一判定的每个分支至少执行一次A=3,B=0,X=3A=2,B=1,X=1
3
条件覆盖
每一判定中的每个条件,分别按“真”、“假”至少各执行一次A=2,B=0,X=4A=1,B=1,X=1
4
判定/条件覆盖
同时满足判定覆盖和条件覆盖的要求A=2,B=0,X=4A=1,B=1,X=1
5(强)
条件组合覆盖
求出判定中所有条件的各种可能组合值,每一可能的条件组合至少执行一次
·
条件覆盖不一定包含判定覆盖;
判定覆盖也不一定包含条件覆盖。
条件组合覆盖是前述几种覆盖标准中最强的。
但是,满足条件组合覆盖标准的测试数据并不一定能使程序中的每条路径都执行到。
例子:
第8章维护
1、什么是软件维护、维护分哪四种类型、其含义分别是什么、在维护工作中占得比例如何?
软件维护定义:
就是在软件已经交付使用之后,为了改正错误或满足新的需要而修正软件的过程。
维护分为四种类型:
(1)改正性维护:
把整断和改正错误的过程称为改正性维护
(2)适应性维护:
为了和变化的环境适当的配合而进行的修改软件的活动,(3)完善性维护:
在使用软件的过程中用户常常提出新增功能或修改已有功能的建议,为了满足这类要求的活动(4)预防性维护:
为了改进将来的可维护性或可靠性;
所占比例:
完善性维护:
50%~66%改正性维护:
17%~21%适应性维护:
18%~25%其他维护:
4%
2、什么是软件的可维护性?
决定软件可维护性的因素有哪些?
造成软件难以维护的原因有哪些?
软件的可维护性:
是指软件维护人员理解、纠正软件系统出现的错误和缺陷,以及为满足新的要求进行修改、扩充或压缩软件的难易程度
决定软件可维护性的五个因素:
(1)可理解性
(2)可测试性(3)可修改性(4)可移植性(5)可重用性
难以维护的原因:
在于这些软件的文档不全、质量差、开发过程不注意采用好的方法,忽视程序设计风格等。
难以维护的根本原因:
软件定义和软件开发的方法有缺点,在软件生命周期的头两个时期没有严格而又科学的管理和规划,没有采用软件工程思想开发软件。
3、文档和可维护性之间的关系?
文档是影响软件可维护性的决定因素,文档往往比代码更加重要;
软件系统的文档可以分为用户文档和系统文档两类
.软件系统的文档可以分为用户文档和系统文档两类.用户文档主要描述系统功能和使用方法,并不关心这些功能是怎样实现的;
系统文档描述系统发设计,实现和测试等各方面的容"
8.4.2文档
分类
用户文档:
主要描述系统功能和使用方法,并不关心这些功能是怎样实现的
系统文档:
描述系统设计、实现和测试等各方面的容
文档要求
必须描述如何使用这个系统,没有这种描述时即使是最简单的系统也无法使用;
必须描述怎样安装和管理这个系统;
必须描述系统需求和设计;
必须描述系统的实现和测试,以便使系统成为可维护的
用户文档
功能描述,说明系统能做什么;
安装文档,说明怎样安装这个系统以及怎样使系统适应特定的硬件配置;
使用手册,简要说明如何着手使用这个系统(应该通过丰富例子说明怎样使用常用的系统功能,还应该说明用户操作错误时怎样恢复和重新启动);
参考手册,详尽描述用户可以使用的所有系统设施以及它们的使用方法,还应该解释系统可能产生的各种出错信息的含义(对参考手册最主要的要完整,因此通常使用形式化的描述技术);
操作员指南(如果需要有系统操作员的话),说明操作员应该如何处理使用中出现的各种情况。
系统文档
问题定义、需求说明到验收测试计划这样一系列和系统实现有关的文档
4、衡量软件质量的主要指标?
可维护性、可使用性、可靠性是衡量软件质量的主要指标
9.面向对象的概念
9.2.1对象
是客观事物或概念的抽象表述,即对客观存在的事物的描述统称为对象
对象可以是事、物、或抽象概念,是将一组数据和使用该数据的一组基本操作或过程封装在一起的实体。
对象的特点
(1)以数据为中心。
(2)对象是主动的。
(3)实现了数据封装。
(4)本质上具有并行性。
(5)模块独立性好。
9.2.2类
类又称对象类(ObjectClass),是一组具有相同属性和相同操作的对象的集合。
在一个类中,每个对象都是类的实例(instance),它们都可以使用类中提供的函数。
9.2.3实例
实例就是由某个特定的类所描述的一个具体的对象。
类是对具有相同属性和行为的一组相似的对象的抽象,类在现实世界中并不能真正存在。
9.2.4消息
消息就是向对象发出的服务请求(互相联系、协同工作等)。
一个消息包含3个部分:
接收消息的对象,消息名,消息变元。
例如,MyCircle是Circle类的一个实例,发送消息如下:
MyCircle.show(GREEN);
9.2.5方法
方法就是对象所能执行的操作,也就是类中所定义的服务。
方法描述了对象执行操作的算法,响应消息的方法。
在C++语言中把方法称为成员函数。
9.2.6属性
属性就是类中所定义的数据,它是对客观世界实体所具有的性质的抽象。
9.2.7封装
对象封装了对象的数据以及对这些数据的操作。
9.2.8继承
继承是指能够直接获得已有的性质和特征,而不必重复定义它们。
在面向对象的软件技术中,继承是子类自动地共享基类中定义的数据和方法的机制。
单重继承:
子类仅从一个父类继承属性和方法
多重继承:
子类可从多个父类继承属性和方法
9.2.9多态性
在类等级的不同层次中可以共享(公用)一个行为(方法)的名字,然而不同层次中的每个类却各自按自己的需要来实现这个行为。
当对象接收到发送给它的消息时,根据该对象所属于的类动态选用在该类中定义的实现算法
有两种重载:
函数重载是指在同一作用域的若干个参数特征不同的函数可以使用相同的函数名字;
运算符重载是指同一个运算符可以施加于不同类型的操作数上面。
当然,当参数特征不同或被操作数的类型不同时,实现函数的算法或运算符的语义是不相同的。
重载进一步提高了面向对象系统的灵活性和可读性。
9.4.2表示关系的符号
类与类之间关系有:
关联,聚集,泛化(继承),依赖,细化
9.4.2.1关联
关联表示两个类的对象之间存在某种语义上的联系。
(1)普通关联
普通关联示例
在表示关联的直线两端可以写上重数(multiplicity),它表示该类有多少个对象与对方的一个对象连接。
重数的表示方法通常有:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 安徽大学 软件工程 复习题