当前位置:文档之家› 《软件工程》复习材料(有答案)

《软件工程》复习材料(有答案)

《软件工程》复习材料(有答案)
《软件工程》复习材料(有答案)

一、写出下列缩写英文的中文涵义[30T]

CFD DFD OOASA SD SP CMM CMMI UMLCASE XP

C/S B/SA TAM PDL SQA MVC CRC MBSCBSD GUI

SQLMTTR MTTF MTBF FTR PERT SCM CPMRMMP

【参考答案】

计算流体动力学(CFD)Computational Fluid Dynamics

数据流图(DFD)Data FlowDiagram

面向对象分析方法(OOA)Object—Oriented Analysis

结构化分析方法(SA) Structured Analysis

结构化设计(SD)Structureddevise

结构化编程(SP)Structured Programming

成熟度模型(CMM)CapabilityMaturity Model

能力成熟度模型集成(CMMI) Capability Maturity Model Integration

统一建模语言(UML)Unified Modeling Language

计算机辅助软件工程(CASE) Computer Aided Software Engineering

极限编程(XP)ExtremeProgramming

客户机/服务器网(C/S) Client/Server

浏览器和服务器结构(B/S)Browser/Server

构架权衡分析方法(ATAM)Architecture Tradeoff AnalysisMethod

页描述语言(PDL)Program DesignLanguage

软件质量保证(SQA)SoftwareQualityAssurance

模型—视图-控制器(MVC)ModelView Controller

循环冗余码校验(CRC)Cyclical RedundancyCheck

相互广播系统(MBS)Mutual BroadcastingSystem

基于构件的软件开发(CBSD)Component—Based SoftwareDevelopment

图形用户界面(GUI)Graphical User Interface

结构化查询语言(SQL)Structured Query Language

平均恢复前时间(MTTR)Mean TimeTo Restoration

平均失效前时间(MTTF)MeanTimeTo Failure

平均无故障时间(MTBF)Mean Time Between Failure

正式技术复审(FTR)Formal Technical Review

计划评审技术(PERT) Program EvaluationAnd Review Technique

软件配置管理(SCM)Software Configuration Management

关键路径方法(CPM)Critical Path Method

二、概念[34]

[1]在《计算机科学技术百科全书中》,对计算机软件作出如下定义:计算机软件指计算机系统中的程序和文档,前者是计算任务的处理对象和处理规则的描述;后者是为了便于了解程序所需的阐述性资料。

[2] 软件和硬件具有完成不同的特性,软件是设计开发的,而不是传统意义上生产制造的。

[3] 软件工程是一种层次化技术,是建立在以质量焦点为基础的,分过程、方法、工具三个研究层次的综合技术.

[4] 软件工程是应用计算机科学、数学及管理学等原理,开发软件的工程,其框架可概括为:目标、过程和原则。

[5]结构化设计方法中,要把数据流图转换成软件结构,若某个加工将它的输入流分离成许多发散的数据流,形成许多加工路径,并根据输入的值选择其中一个路径来执行,这种特征的DFD称为事务型的数据流图。

[6]数据流图仅反映系统必须完成的逻辑功能,所以它是一种功能模型.

[7]耦合性是定性度量模块独立性的标准之一,它根据模块的外部特征提出的,是对软件系统结构中各模块间相互联系紧密程度的一种度量,也称块间关系。

[8]衡量软件的独立性有两个定性的度量标准,即耦合和内聚。

[9]任何程序都可由选择结构、循环结构和顺序结构3种基本控制结构构造,其共同点是单入口、单出口。

[10]统一过程(UP)是一种用例驱动的迭代式增量开发过程,每次迭代过程中主要的工作流包括捕获需求、分析、设计、实现和测试等,这种软件过程的用例图式通过分析得到. [11]软件开发是一个自顶向下逐步细化和求精过程,而软件测试是一个自底向上或相反顺序集成的过程。

[12]软件测试的目的是尽可能多地发现软件中存在的错误,将测试结果作为纠错的依据。[13] 软件质量定义为:与所确定的功能和性能需求的一致性;与所成文的开发标准的一致性;与所有专业开发的软件所期望的隐含特性的一致性。

[14] LOC是软件规模的一种量度,它表示源代码行数

[15]参照以前完成的项目所耗费的总成本来推算将要开发的软件的总成本,然后把它们按阶段、步骤和工作单元进行分配,这种方法被称为自顶向下方法。

[16] 在统一建模语言(UML)中,描述系统与外部系统及用户之间交互的图是用例图。[17] 如果一个软件是给许多客户使用的,大多数软件厂商要使用几种测试过程来发现那些可能只有最终用户才能发现的错误,beta测试(β测试)是由软件的最终用户在一个或多个用户实际使用环境下来进行的.

[18]结构化分析方法(SA)的一个重要指导思想是自顶向下,逐步分解。

[19] 软件从一个计算机系统转换到另一个计算机系统运行的难易程度是指软件可移植性[20]在进行面向对象设计时,采用设计模式能够复用相似问题的相同解决方案

[21]面向对象分析需要找出软件需求中客观存在的所有实体对象,然后归纳、抽象出实体类。名词分析是寻找实体对象的有效方法之一。

[22]需求分析最终结果是产生需求规格说明书

[23]软件结构图中,模块框之间若有直线连接,表示它们之间存在调用关系?

[24].在软件开发过程中,软件设计包括4个既独立又相互联系的活动,分别为体系结构设计、接口设计、数据设计和过程设计.

[25] 进行软件项目的风险分析时,风险避免、风险监控和风险管理及意外事件计划是风险

控制活动中需要考虑的问题。

[26]开发软件所需高成本和产品的低质量之间有着尖锐的矛盾,这种现象称为软件危机[27]黑盒测试在设计测试用例时,主要需要研究需求规格说明与概要设计说明

[28]如果一个软件是给许多客户使用的,大多数软件厂商要使用几种测试过程来发现那些可能只有最终用户才能发现的错误,alpha测试(α测试)是由一个用户在开发者的场所来进行的,测试的目的是寻找错误的原因并改正之。

[29]软件质量必须在设计和实现的过程中加以保证,为了确保每个开发过程的质量,防止把软件差错传递到下一过程,必须进行质量检验

[30] 甘特(Gantt)图的作用是什么?[以课本为主]

通过条状图来显示项目,进度,和其他时间相关的系统进展的内在关系随着时间进展的情况。[31]面向对象具有继承性、多态性、封装性、信息隐蔽等特征

[32]白盒和黑盒测试各有哪些方法。[以课本为主]

白盒方法:

·代码检查法

·静态结构分析法

·静态质量度量法

·逻辑覆盖法

·基本路径测试法

·域测试

·符号测试

·Z路径覆盖

·程序变异

黑盒方法:

·等价类划分方法

·边界值分析方法

·错误推测方法

·因果图方法

·判定表驱动分析方法

·正交实验设计方法

·功能图分析方法

[33]软件度量有哪些方法[以课本为主]

·功能点分析(FPA:function pointsanalysis)

·代码行(LOC:lines of code)

·德尔菲法(Delphi technique)

·COCOMO模型、特征点(featurepoint)

·对象点(object point)

·3—D功能点(3—Dfunction points)

·Bang度量(DeMarco's bang metric)

·模糊逻辑(fuzzy logic)

·标准构件法(standard component)等

[34]成本估算有哪些方法[以课本为主] 自顶向下和自底向上

三、名词解释[10T]

信息隐蔽可靠性用例正确性可移植性基线再工程重构集成测试场景

[1]信息隐蔽:是指在设计和确定模块时,使得一个模块内包含的信息(过程或数据),对于不需要这些信息的其他模块来说是不能访问的。

[2] 可靠性:一个程序期望以所需的精确完成它的预期功能的程度。

[3]用例:一组场景,用以共同描述用户的某个特定的目标。

[4] 正确性:一个程序满足它的需求规约以及实现客户任务目标的程度.

[5] 可移植性:软件从一个计算机系统转换到另一个计算机系统运行的难易程度.

[6] 基线:是指已经经过正式审核和同意,可用作下一步开发的基础,且只有通过正式的修改管理过程方能加以修改的规约说明或产品.

[7]再工程:逆向工程+重构+正向工程

[8] 重构: 就是在不改变软件现有功能的基础上,通过调整程序代码改善软件的质量、性能,使其程序的设计模式和架构更趋合理,提高软件的扩展性和维护性。

[9]集成测试:也称组装测试或联合测试,是指在单元测试的基础上,将所有模块按照设计要求组装成一个完整的系统进行的测试.组装模块的方式有两种:渐增式测试和非渐增式测试.

[10]场景:用户与系统之间的一个交互过程,即为实现这次交互所要经历的一系列步骤。

四、案例分析[7T]

[1]阅读以下说明和图,回答问题1至问题4。某高校欲开发一个成绩管理系统,记录并管理所有选修课程的学生的平时成绩和考试成绩,其主要功能描述如下:

1)每门课程都有3到6个单元构成,每个单元结束后会进行一次测试,其成绩作为这门课程的平时成绩。课程结束后进行期末考试,其成绩作为这门课程的考试成绩。

2)学生的平时成绩和考试成绩均由每门课程的主讲教师上传给成绩管理系统.

3)在记录学生成绩之前,系统需要验证这些成绩是否有效。首先,根据学生信息文件来确认该学生是否选修这门课程,若没有,那么这些成绩是无效的;如果他的确选修了这门课程,在根据课程信息文件和课程单元信息文件来验证平时成绩是否与这门课程所包含的单元相对应,如果是,那么这些成绩是有效的,否则是无效的.

4)对于有效成绩,系统将其保存在课程成绩文件中.对于无效成绩,系统会单独将其保存在无效成绩文件中,并将详细情况提交给教务处。在教务处没有给出具体处理意见之前,系统不会处理这些成绩.

5)若一门课程的所有有效的平时成绩和考试成绩都已经被系统记录,系统会发送课程完成通知给教务处,告知该门课程的成绩已经齐全。教务处根据需要,请求系统生成相应的成绩列表,用来提交考试委员会审查。

6)在生成成绩列表之前,系统会生成一份成绩报告给主讲教师,以便核对是否存在错误。主讲教师必须将核对之后的成绩报告返还系统。

7)根据主讲教师核对后的成绩报告,系统生成相应的成绩列表,递交考试委员会进行审查。

考试委员会在审查之后,上交一份成绩审查结果给系统。对于所有通过审查的成绩,系统将会生成最终的成绩单,并通知每个选课学生。

现采用结构化方法对这个系统进行分析与设计,得到如图(1)所示的顶层数据流图和图(2)所示的0层数据流图.

图(1)顶层数据流图

图(2)第0层数据流图

[问题1]使用说明中的词语,给出图(1)中的外部实体E1~E4的名称。

[问题2]使用说明中的词语,给出图(2)中的数据存储D1~D5的名称。

[问题3]数据流图(2)中缺少了三条数据流,根据说明及数据流图(1)提供的信息,分别指出这三条数据流的起点和终点。

【分析】

本题考查的是DFD的应用,属于比较传统的题目,考查点也与往年类似。

【问题1】

外部实体是在系统边界之外的个人和组织,它提供数据,或者接受数据输出.

根据主要功能描述:"学生成绩均由每门课程的主讲教师上传给成绩管理系统”,所以主讲教师是一个外部实体,根据顶层流程图,得知E2处应填”主讲教师”;”对于无效成绩,系统会单独将其保存在无效成绩文件中,并将详细情况提交给教务处"各"成绩已经被系统记录,系统会发送课程完成通知给教务处,告知该门课程的成绩已经齐全。"在这里"教务处"是一个外部实体,应填在E4处。"根据主讲教师核对后的成绩报告,系统生成相应的成绩列表,递交考试委员会进行审查。考试委员会在审查之后,上交一份成绩审查结果给系统."在这里考试委员会是一个外部实体,应填在E1处;”对于所有通过审查的成绩,系统将会生成最终的成绩单,并通知每个选课学生."在这里"选课学生"是一个外部实体,应填在E 3处。

【问题2】

数据存储是保存数据的地方,将来一个或者多个过程会访问这些数据。

根据0层数据流图,在"验证学生信息"处有3个数据输入,根据"在记录学生成绩之前,系统需要验证这些成绩是否有效。首先,根据学生信息文件来确认该学生是否选修这门课程,若没有,那么这些成绩是无效的;如果他的确选修了这门课程,再根据课程信息文件和课程单元信息文件来验证平时成绩是否与这门课程所包含的单元相对应,如果是,那么这些成绩是有效的,否则无效。"得知由学生信息文件、课程单元信息文件、课程信息文件共3个文件帮助验证:在"生成成绩列表"处也要利用到D1文件,现已输入了成绩审查结果、核对后的成绩报告,只缺"学生信息文件”,所以D1处应填”学生信息文件";D2和D3处分别填" 课程单元信息文件”和”课程信息文件”。D4是”记录有效成绩"的一个输出文件,根据"对于有效成绩,系统将其保存在课程成绩文件中."知D4处应填"课程成绩文件";D5是"记录无效成绩”的输出文件,根据"对于无效成绩,系统会单独将其保存在无效成绩文件中。",D5处应填"无效成绩文件”。

【问题3】

在0层数据流图中的"4生成成绩列表"处没有课程成绩文件输入,不可能生成成绩列表.所以在此处缺少一条从”D4课程成绩文件"到"4生成成绩列表"的数据流。

”5生成最终成绩单”没有任何输入,不符合数据输入/输出平衡,根据”根据主讲教师核对后的成绩报告,系统生成相应的成绩列表,递交考试委员会进行审查。考试委员会在审查之后,上交一份成绩审查结果给系统。对于所有通过审查的成绩,系统将会生成最终的成绩单”,所以应根据”学生信息文件"和"生成成绩列表"才能生成最终成绩单,所以还应补充从”D1学生信息文件"到"5生成最终成绩单”的数据流和"4生成成绩列表"到”5生成最终成绩单”的数据流.

【问题4】

程序流程图通常在进行详细设计时使用,用来描述程序的逻辑结构(功能需求)。

【参考答案】

【问题1】(4分)

E1:考试委员会;E2:主讲教师; E3:学生或选课学生;E4:教务处

【问题2】(3分)

D1:学生信息文件;D2:课程单元信息文件;D3:课程信息文件;

D4:课程成绩文件;D5:无效成绩文件

注:D2和D3的答案可以互换。

【问题3】(6分)

D4或 课程成绩文件 4 或 生成成绩列表

D 1或 学生信息文件 5 或 生成最终成绩单

4 或 生成成绩列表 5 或 生成最终成绩单

注:[2] 某培训中心要研制一个计算机管理系统。它的业务是:将学员发来的信件收集分类后,按几种不同的情况处理。

1) 如果是报名的,则将报名数据送给负责报名事务的职员,他们将查阅课程文件,检查该课程是否额满,然后在学生文件、课程文件上登记,并开出报告单交财务部门,财务人员开出发票给学生。

2) 如果是想注销原来已选修的课程,则由注销人员在课程文件、学生文件和账目文件上做相应的修改,并给学生注销单。

3) 如果是付款的,则由财务人员在账目文件上登记,也给学生一张收费收据。 通过分析该问题,得数据流图如图3所示。

[问题1] 数据流图(3)中有三条数据流是错误的,请写出改正后的这三条数据流的起点和终点。

[问题 2]依据上述说明中给出的词语,将图(1)中的【1】、【2】处补充完整.

[1]账目、[2]学生

[问题 3] 根据图(3)的类型,若要完成软件结构设计,则采用 自顶向下、逐次功能展开 ? 方法.

图3 数据流图

学生文件

账目文件 课程文件 学员 收集 分类 注销 报名 发票 学员

账目学生

图3修改后数据流图

参考数据流图

[3]某指纹门禁系统的体系结构如图(4)所示,其主要部件有:主机(MainFrame)、锁控器(LockControler)、指纹采集器(FingerReader)和电控锁(Lock)。

1)系统中的每个电控锁都有一个唯一的编号。锁的状态有两种:“已锁住”和“未锁住”.

2)在主机上可以设置每把锁的安全级别以及用户的开锁权限。只有当用户的开锁权限大于

或等于锁的安全级别并且锁处于“已锁住”状态时,才能将锁打开。

3)用户的指纹信息、开锁权限以及锁的安全级别都保存在主机上的数据库中。

4)用户开锁时,只需按一下指纹采集器。指纹采集器将发送一个中断事件给锁控器,锁控

器从指纹采集器读取用户的指纹并将指纹信息发送到主机,主机根据数据库中存储的信息来判断用户是否具有开锁权限,若有且锁当前处于“已锁住”状态,则将锁打开,否则系统报警。

该系统采用面向对象方法开发,系统中的类以及类之间的关系用UML类图表示,图(5)是该系统类图的一部分;系统的动态行为采用UML系列图表示,图(6)是用户成功开锁的序列图。

付款

图(4)体系结构

图(5)系统类图

图(6)序列图

[问题1]图(5)是该系统类图的一部分,依据上述说明中给出的术语,给出类Lock的主要属性.

[问题2]?依据上述说明中给出的词语,将图(6)中的(1)~(5)处补充完整.

【分析】

本题是一道使用面向对象方法进行系统开发的题目,主要考查利用UML的类图和序列图进行面向对象的分析。

类图是面向对象系统的建模中最常见的图.类图显示了一组类、接口、协作以及它们之间的关系.类图用于对系统静态设计视图建模。在图形上,类图是顶点和弧的集合.在类图中通常包含:类、接口、协作、依赖、泛化和关联关系。类图还可以含有包或者子系统,二者都用于把模型元素聚集成更大的组块.

当对系统的静态设计视图建模时,通常以下述3种方式之一使用类图。

①对系统的词汇建模。对系统的词汇建模涉及做出这样的决定:哪些抽象是考虑中的系统的一部分,哪些抽象处于系统边界之外。用类图详细描述这些抽象和它们的职责。

②对简单的协作建模。协作是一些共同工作的类、接口和其他元素的群体,该群体提供的一些合作行为强于所有这些元素的行为之和。

③对逻辑数据库模式建模。将模式看作为数据库的概念设计的蓝图.在很多领域中,要在关系数据库或面向对象数据库中存储永久信息。可以用类图对这些数据库的模式建模。

序列图是场景的图形化表示,描述了以时间顺序组织的对象之间的交互活动.序列图有两个特征:

序列图有对象生命线.对象生命线是一条垂直的虚线,表示一个对象在一段时间内存在。在交互图中出现的大多数对象存在于整个交互过程中,所以这些对象全都排列在图的顶部,其生命线从图的顶部画到图的底部.但对象也可以在交互过程中创建,它们的生命线从接收到构造型为create的消息时开始。对象也可以在交互过程中撤销,它们的生命线在接收到构造型为destroy的消息时结束(并且给出一个大X的标记表明生命的结束)。

序列图有控制焦点。控制焦点是一个瘦高的矩形,表示一个对象执行一个动作所经历的时间段,既可以是直接执行,也可以是通过下级过程执行。矩形的顶部表示动作的开始,底部表示动作的结束(可以由一个返回消息来标记)。还可以通过将另一个控制焦点放在它的父控制焦点的右边来显示(由循环、自身操作调用或从另一个对象的回调所引起的)控制焦点的嵌套(其嵌套深度可以任意)。如果想特别精确地表示控制焦点在哪里,也可以在对象的方法被实际执行(并且控制还没传给另一个对象)期间,将那段矩形区域阴影化.

【问题1】

图3-2给出了一个不完整的类图,已经完成了面向对象分析中的认定类,下一步的工作是定义类的内部信息,本题主要考查如何从问题域中抽象出类的属性。由于已经确定了类,寻找类的属性就相对容易了。

类Lock是本系统中的一个关键类,与它的属性相关的描述有:"系统中的每个电控锁都有一个唯一的编号”、”锁的状态有两种”、”在主机上可以设置每把锁的安全级别”。"锁的编号"、”锁的状态”以及”锁的安全级别”都是用来说明Lock的属性及特性的,也是类Lock的关键属性。

【问题2】

序列图显示了一组对象和由这组对象发送和接收的消息。创建序列图时,首先应确定要建模的内容。它是针对一个用例的基本活动过程吗?一个候选过程?还是基本活动过程与一个或多个候选过程的组合?本题中并没有给出用例图,但是题目的说明已经指出了图3-3所示的序列图的建模内容:用户成功开锁的活动。

用户开锁的过程在说明中的(4)给出。序列图是按照时间顺序组织的对象之间的交互活动,因此需要将这些活动按照时间顺序排序,并记录下参与每个活动的对象。

用户开锁的激发事件是:用户按下指纹采集器。

相关主题
文本预览
相关文档 最新文档