软件工程背诵笔记
文章目录
- 一、简答题
- 第一章
- 1. 与计算机硬件相比,计算机软件有哪些特点?
- 3.什么是软件危机?什么原因导致了软件危机?
- 5.请简述软件工程研究的内容
- 7.请简述软件工程的目标、过程和原则
- 9.请简述现代软件工程与传统软件工程显著的区别和改进。
- 第二章
- 1.如何理解软件生命周期的内在特征
- 3.当需求不能一次搞清楚,且系统需求比较复杂时应选用哪种开发模型比较合适?
- 5.XP是一种什么样的模型
- 7.请简述软件过程
- 9.请简述CMM的作用
- 11.假设你要开发一个软件,它的功能是把73624.9285开平方,所得到的结果应该是精确到小数点后四位。一旦实现并测试完后,该产品将被抛弃。你打算选用哪种软件生命周期模型?请说明你做出这样选择的理由。
- 第五章
- 1.在选择编程语言时,通常要考虑哪些因素?
- 3.什么是调试?什么是测试?二者有何区别?
- 5.请简述静态测试和动态测试的区别
- 7.软件测试的目的是什么?
- 9.什么是白盒测试?有哪些常用的白盒测试方法?
- 11.软件测试应该划分为几个阶段?各个阶段应重点测试的内容是什么?
- 第十一章
- 第十二章
- 第十三章
- 第十四章
一、简答题
第一章
1. 与计算机硬件相比,计算机软件有哪些特点?
软件的特点如下。
●无法直接观察计算机软件的物理形 态,只能通过观察它的实际运行情况来了解它的功能、
特性和质量等。
●人们在分析、设计、开发、测试软件产品,以及在软件开发项目的管理过程中,渗透了大
量的脑力劳动。
●不存在像硬件- -样的磨 损和老化现象,但存在着缺陷维护和技术更新的问题。
●软件的开发和运行必须依赖于特定的计算机系统环境。
●具有可复用性。
3.什么是软件危机?什么原因导致了软件危机?
软件危机的现象如下。
经费超出预算,项目一再拖延。
●不重视需求,开发的软件不能满足用户的要求,项目成功率低。
●没有规范的软件工程方法,软件可维护性差、软件质量差、可靠性差。
●开发工具落后,手工方式,开发效率低。所有导致软件危机的原因,都与软件本身的产品特点相关。
●软件是一一个复杂的逻辑产品。如果没有解决复杂问题的有效方法,以及软件产品的结构、质量、可维护性得不到保障,开发与维护费用就会持续升高。
●软件产品不能实现大规模复用,这导致了软硬件生产效率的不同。
●软件生产是脑力劳动,它看不见、摸不着,开发成本、开发周期等都无法做到准确估算,生产过程不易控制。
●软件成本主要是由研发成本构成;而硬件的生产成本主要是材料和制造成本,分摊的研发成本很少,即软件研发过程与硬件制造过程相比要复杂得多。
5.请简述软件工程研究的内容
5.软件工程研究的内容包括软件开发方法、软件开发模型、软件支持过程和软件管理过程。
●软件开发方法的内容涵盖市场调研、正式立项、需求分析、项目策划、概要设计、详细设
计、编程、测试、试运行、产品发布、用户培训、产品复制、销售、实施、系统维护、版本升
级等。
●常用的软件开发模型有瀑 布模型、迭代模型、增量模型和原型模型等。
●软件支持过 程由所支持的CASE工具组成,常用的CASE工具有Power Designer和Rational
Rose等。
7.请简述软件工程的目标、过程和原则
7.目标、过程和原则是一切工程的三维框架,这里是以工程的观点来看待软件开发。
●软件工程的目标:降低成本、及时交付高质量的软件产品(高质量、高效率、高效益)。.
●实现目标的过程即完成产品加工的过程,包括:基本过程、支持过程和组织过程。
●进行过程应遵守的原则:原则就是过程中的轨道约束,包括:选取适宜的开发范型、采用
合适的设计方法、提供高质量的工程支持、重视开发过程的管理。
9.请简述现代软件工程与传统软件工程显著的区别和改进。
9.传统的软件工程是基于结构化的软件开发方法,而现代软件工程是以面向对象技术为
标志。
●不仅在编程技术上有很大的改进,而且在分析、设计等整个开发过程中,采用面向对象的
思维方式,更加完整、自然地反映客观世界。
●采用架构技术,开发效率、产品质量得到了极大提高。
●更注重团队开发和管理,融人更多、更新的管理理念和手段,如RUP模型、XP模型、过
程改进、能力成熟度模型、配置管理等。
第二章
1.如何理解软件生命周期的内在特征
1.软件产品的生命周期是指从设计该产品的构想开始,到软件需求的确定、软件设计、软件
实现、产品测试与验收、投人使用以及产品版本的不断更新,再到最终该产品被市场淘汰的全过程。软件生命周期这个概念从时间的角度将软件的开发和维护的复杂过程分解为了若干个阶段,
每个阶段都完成特定的相对独立的任务。由于每个阶段的任务相对于总任务难度会大幅度降低,
因此在资源分配、时间把握和项目管理上都会比较容易控制。应该合理地划分软件生命周期的各
个阶段,使各个阶段之间既相互区别又相互联系,为每个阶段赋予特定的任务。
3.当需求不能一次搞清楚,且系统需求比较复杂时应选用哪种开发模型比较合适?
3.开发模型不是孤立或排斥的,它们之间需要相互借鉴和参考。螺旋模型是一种综 合性的模
型,适和于较复杂的系统。
5.XP是一种什么样的模型
- XP是现代版的增量模型,特点是客户参与、适应变化、测试驱动、以代码为核心。实行
XP的条件如下。
●企业具有 较高的能力成熟度,具有团队开发环境和配套的测试工具。
●软件结构是开放的,增量可随意整合。
●开发团队拥有 “系统隐喻”。
7.请简述软件过程
7.软件过程就是软件产品的加工过程,其本质就是将“客观世界”映射(虚拟)到“计算机世
界",即从抽象到具体的逐步细化过程。系统分析就是对客观世界的抽象,中间要经过分析模
型、设计模型的逐步细化(具体化),最终的具体结果就是计算机世界里的代码。
9.请简述CMM的作用
- CMM的作用如下。
●CMM是评价软件组织开发能力(水平)的参考模型,是一种认证标准,认可软件工程达
到的程度(如同评定职称的条件)。
●CMM是软件组织提升自身能力、走向成熟的参照系。它提供了走向成熟的阶梯目标,但
并不提供走向目标的方法。
●CMM等级的提高依靠软件过程改进。
●CMM既是评估软件能力成熟度的模型,也起到了促进软件企业按照该模型设置的级别和
关键过程域不断改进自己的软件过程的作用。
11.假设你要开发一个软件,它的功能是把73624.9285开平方,所得到的结果应该是精确到小数点后四位。一旦实现并测试完后,该产品将被抛弃。你打算选用哪种软件生命周期模型?请说明你做出这样选择的理由。
- 对这个软件的需求很明确,实现开平方功能的算法也很成熟。因此,既无须通过原型模
型来分析需求也无须用原型模型来验证设计方案。此外,- -旦实现并测试完之后,该产品将被抛
弃,因此也无须使用有助于提高软件可维护性的增量模型或螺旋模型来开发该软件。
综上所述,为了开发这个简单的软件,使用大多数人所熟悉的瀑布模型就可以了。
第五章
1.在选择编程语言时,通常要考虑哪些因素?
1.在选择编程语言时,通常需考虑以下因素
●待开发系统的应用领域, 即项目的应用范围。
●用户的要求。
●软件开发人员的喜好和能力。
●系统的可 移植性要求。
●算法和数据结构的复杂性。
3.什么是调试?什么是测试?二者有何区别?
3.调试( debug )指的是对模块的调试,是程序员交付可运行的代码模块所必须经历的工作。
软件测试(test) 有如下特点。
●软件测试的目的是发现程序中的错误,是为了证明程序有错,而不是证明程序无错。
●不仅仅是测试程序, 还应该对开发过程中所有的产品进行测试,包括文档,其目的是为了
尽早地、尽可能多地发现并排除软件中潜在的错误。
5.请简述静态测试和动态测试的区别
5.按照执行测试时是否需要运行程序,软件测试可以划分为静态测试和动态测试。
静态测试以人工测试为主,通过测试人员认真阅读文档和代码,仔细分析其正确性、一致性
及逻辑结构的正确性,从而找出软件产品中的错误或缺陷。静态测试对自动化工具的依赖性较小,
通过人脑的思考和逻辑判断来查找错误,因而可以更好地发挥人的主观能动性。
与静态测试不同的是,动态测试需要通过实际运行被测程序来发现问题。测试人员可以输人一
系列的测试用例,通过观察测试用例的输出结果是否与预期相符来检验系统内潜在的问题或缺陷。
7.软件测试的目的是什么?
7.测试的目的如下。
●测试是一个为 了发现程序中的错误为目的的程序执行过程。
●一个好的测试用例是能最大限度地找到迄今为止尚未发现的错误。
●成功的测试是能发现 了那些尚未发现的错误。
9.什么是白盒测试?有哪些常用的白盒测试方法?
9.白盒测试主要针对于程序内部逻辑和数据流程的测试,因此白盒测试的测试用例设计需要
了解程序的内部逻辑。常用的白盒测试方法主要有逻辑覆盖法、基本路径测试法。
#9.白盒测试主要针对于程序内部逻辑和数据流程的测试,因此白盒测试的测试用例设计需要
了解程序的内部逻辑。常用的白盒测试方法主要有逻辑覆盖法、基本路径测试法。
11.软件测试应该划分为几个阶段?各个阶段应重点测试的内容是什么?
- 软件测试总的来说可分为单元测试、集成测试、系统测试、验收测试。每个阶段又分为确定测试计划,测试设计,设计测试用例,实施测试,进行测试报告5个步骤。
●单元测试是对软件中的基本组成单位进行的测试,如一个模块、一个过程等。它是软件动
态测试的最基本的部分,也是最重要的部分之- - ,其目的是检验软件基本组成单位的正确性。
集成测试是软件系统集成过程中所进行的测试,其主要目的是检查软件单位之间的接口是
否正确。
●系统测试是对已经集成好的软件 系统进行彻底的测试,以验证软件系统的正确性和性能等
满足其规约所指定的要求,检查软件的行为和输出是否正确并非是- -项简单的任务,它被称为测
试的“先知者问题”。
●验收测试是向软件的购买者展示该软件系统满足其用户的需求。它的测试数据通常是系统
测试的测试数据的子集。
●回归测试是在软件维护阶段,对软件进行修改之后进行的测试。其目的是检验对软件进行
的修改是否正确。
第十一章
1.请简述项目、项目管理、和软件项目管理
1.项目、项目管理和软件项目管理的概念如下。
●项目是一次性的多任务工作,它具有确定的开始日期、结束日期、工作范围、经费预算、
质量标准,以及特定的功能、性能和接口要求。
●项目管理是为了实现项目目标,运用相关的知识、技能、方法与工具,对项目的计划、进.
度、质量、成本、资源进行管理和控制的活动。
●软件项目管理以通用的项目管理知识体系为基础,管理的对象是软件工程项目。它结合软
件工程自身的科学规律,采用适合软件产品自身特点的管理方法,使得整个软件开发过程(从分
析、设计、编码到测试、维护全过程)都能在管理者的控制之下,以预定成本按期、按质的完成
软件交付用户使用。
3.请简述项目计划应该包括的内容
3.项目计划应该包括的内容如下。
●确定详细的项目实施范围。
●定义递交的工作成果。
●评估实施过程中主要的风险。
制定项目实施的时间计划。
成本和预算计划。
●人力资源计划等。
5.如何进行项目的时间管理
5.项目的时间管理首先要对项目活动进行定义,依据包括:工作分解结构、项目范围说明、
历史信息、约束条件、假定和专家评论。
在整个项目中,我们需要- -份能清晰描述活动发生的时间和所需要的资源的计划,项目进度
安排的内容为如下。
●定义一组项目活动,并建立活动之间的相互关系。
●估算各个活动的工作量和完成任务所需要的资源。
●定义里程碑。
●分配人力和其他资源,制定进度时序。
●检查进度安排,确保任务之间没有冲突,并且包含了完成项目必需的所有任务。
7.请简述估算的作用
7.计划是项目的启动入口,项目开展过程就是执行计划。而估算是制定计划的依据,因此估
算是项目开展的基础。估算的主要工作如下。
●范围估算:搞清软件边界。
●规模估算:定量单位采用LOC或FP。
●工作量估算:工作量估算决定了开发团队的规模和组建,决定开发周期和进度估算。
●开发周期与进度估算:进度估算是对整个开发周期中不同阶段的里程碑进行估算。
●人力资源估算:在考虑各种软件开发资源时,人是最重要最优先考虑的资源。
●开发成本估算:整个开发周期所花费的工作量产生的劳动费用。
●软硬件资源估算:软件开发所需的硬件工具及软件工具。
9.请简述做进度计划的两种方式
9.做进度计划的两种方式如下。
●Gantt 图用线段标明子任务的分解;标明各个任务的计划开始时间、完成时间;标明各个
任务与参与工作的人数,各子任务间的并行和串行的关系的衔接情况。
特点:简单、明了、直观、易于编制;以文档与评审作为开发进度的里程碑。
缺点:无法标明多个任务之间存在的相互制约关系;无法标明关键的控制作业。
●工程网络图是用时间和节点来表示工作流程的有序、有向的网状图形。它可弥补Gantt图
无法表达关键路径和作业之间的制约关系,并且易于调整。
第十二章
1.目前项目开发时常用的小组组织方法有哪些?
1.目前,项目开发时常用的小组组织方法:民主制程序员组、主程序员组和现代程序员组。
3.民主制、主程序员制各存在什么问题?
3.民主制程序员组中所有程序员不分主次,这样在责任落实、分工协作方面存在一些问题。
责任不明,分工不清,大家都负责,实际上没有人负责。
主程序员制是主程序员负责制,克服了民主制的缺点,但又走到了另一个极端一只有 主程
序员负责,其他成员的积极性就被扼杀了。另外,主程序员这个位置既是一个技术岗位,也是一个管理角色,这样的位置很难找到胜任的人担任。热衷于技术的人,往往对管理不感兴趣,而具.
有管理才能的人,大多不会是技术专家。
第十三章
1.风险识别的步骤是什么?
1.风险识别分为三步进行:收集资料;估计项目风险形势;识别风险。
3.请简述软件质量的定义
3.所谓软件质量,就是供方提供的软件产品满足用户明确和隐含需求的能力特性的总和。
5.什么是配置项?什么是配置管理?
5.软件配置管理中的基本单元,称为软件配置项。
在开发过程中,将软件的文档、程序、数据进行分割与综合,以利于软件的定义、标识、跟
踪、管理,使其最终形成受控的软件版本产品,这一-管 理过程称为软件配置管理。
7.请简述软件配置管理的工作内容
7.配置管理的工作内容一-般包括如下的4 个方面。
①标识配置项。配置项是配置管理中的基本单元,每个配置项应该包含相应的基本配置管理
的信息。标识配置项就是要给配置项取-一个合适的名字。
②进行配置控制。进行配置控制是配置管理的关键,包括存取控制、版本控制、变更控制和
产品发布控制等。存取控制通过配置管理中的“软件开发库"、“软件基线库”、“软件产品库"来
实现。每个库对应着不同级别的操作权限,为团队成员授予不同的访问权利。版本控制往往使用
自动的版本控制工具来实现,如SVN。变更控制是应对软件开发过程中各种变化的机制,可以通
过建立控制点和报告与审查制度来实现。产品发布控制面向最终发布版本的软件产品,旨在保证
提交给用户的软件产品版本是完整、正确和一致的。
③记录配置状态。配置状态报告记录了软件开发过程中每一次配置变更 的详细信息。记录配
置状态的目的是使配置管理的过程具有可追踪性。
④执行配置审计。配置审计是为了保证软件工作产品的一致性和完整性,从而保证最终软件
版本产品发布的正确性。
第十四章
1.为什么要进行软件维护?软件维护的作用有哪些?
1.软件维护是软件产品生命周期的最后-一个阶段。在产品交付并且投入使用之后,为了解决
在使用过程中不断发现的各种问题,保证系统正常运行,同时使系统功能随着用户需求的更新而
不断升级,软件维护的工作是非常必要的。概括地说,软件维护就是指在软件产品交付给用户之
后,为了改正软件测试阶段未发现的缺陷,改进软件产品的性能,补充软件产品的新功能等,所
进行的修改软件的过程。
3.传统软件维护分为哪几大类?
3.传统软件维护分4类,分别是纠错性维护、适应性维护,完善性维护和预防性维护。
5.请简述结构化维护和非结构化维护
5.结构化维护的前提是软件产品或软件项目必须有完善的文档,并且文档与程序代码互相匹
配,两者完全一致。在这样的前提下,维护不但会比较省力,而且维护后可以用原来的测试用例进行回归测试。相反,若软件产品或软件项目只有程序而没有文档,或文档很不规范、很不齐全,对这样的
软件进行维护,则称为非结构化维护。
7.请简述面向缺陷的维护
7.面向缺陷维护的内容:该软件产品能够正常运行,可以满足用户的功能、性能、接口需求,
只是维护前在个别地方存在缺陷,用户不是非常满意。克服缺陷的方法是修改程序,也就是通常
说的只修改程序,不修改数据结构。
9.怎样理解迭代模型RUP对软件维护的影响?
- RUP 的功能覆盖整个软件的开发周期,从需求分析开始,直到软件的发布、实施和维护
为止,因而它对传统意义下的维护工作产生重大影响。
RUP把软件生命周期定义为4个主要阶段:初始、细化、构造、移交。经过这4个阶段的历
程被称为一一个开发周期,自动产生一个周期内的所有文档,从而生成一- 个软件产品。首次经历这
4个阶段称为该产品的初开发周期。除非该产品的生命终止,否则它将重复初始、细化、构造和
移交这4个阶段,从而演化为下- -代产品,这就是对旧有产品的维护,也是新产品的升级换代,
也就是开发周期的演化,也就是RUP对软件维护工作的影响。
11.请简述软件文档的意义。
11.文档是指某种数据媒体和其中所记录的数据。它具有永久性,并可以由人或机器阅读,
通常仅用于描述人工可读的东西。在软件工程中,文档常常用来表示对活动、需求、过程或结果
进行描述、定义、规定、报告或认证的任何书面或图示的信息。它们描述和规定了软件设计和实
现的细节,说明使用软件的操作命令。文档也是软件产品的一部分,没有文档的软件就不能称其
为软件。软件文档的编制在软件开发工作中占有突出的地位和相当大的工作量。高质量、高效率
地开发、分发、管理和维护文档对于转让、变更、修正、扩充和使用文档,对于充分发挥软件产
品的效益有着重要的意义。