简答题:
软件工程的内容和方法
1.开发文档都有哪些?用图来表示他们之间的关系。
开发文档包括目标程序、源程序、详细设计说明书、概要设计说明书、需求规格说明书、用户需求报告、软件合同,它们之间的关系如图所示。
2.说明软件工程研究的内容。
软件工程研究的内容包括软件开发方法、软件开发模型、软件支持过程和软件管理过程。
其中软件开发方法的内容又含盖市场调研、正式立项、需求分析、项目策划、概要设计、详细设计、编程、测试、试运行、产品发布、用户培训、产品复制、销售、实施、系统维护、版本升级。
常用的软件开发模型有瀑布模型、迭代模型、增量模型和原型模型。
软件支持过程由所支持的CASE工具组成,常用的CASE工具有PowerDesigner和RationalRose。
软件管理过程主要有CMMI、ISO9000、微软企业文化和敏捷文化现象。
3.请详细解释软件的定义和程序的定义。
软件的定义:软件=程序+数据+文档。这里的程序是指程序系统。这里的数据不仅包括初始化数据、测试数据,而且包括研发数据、运行数据、维护数据,也包括软件企业积累的项目工程数据和项目管理数据中的大量决策原始记录数据。这里的文档指的是软件开发过程中的分析、设计、实现、测试、维护文档、管理文档。
现在有一种新提法正在引起关注,这种提法是:软件=知识+程序+数据+文档。
程序是计算机为完成特定任务而执行的指令的有序集合。从应用的角度可理解为:
面向过程的程序=算法+数据结构
面向对象的程序=对象+信息
面向构件的程序=构件+构架
4.是否存在这样一种现象:搞系统软件的公司不需要采用CMMI和ISO9000模式?CMMI
和ISO模式只适用于搞应用软件的企业?如果是,为什么?如果不是,又是为什么?
不是。因为CMMI和ISO9000模式规定了严格的管理制度、文档和评估软件能力与成熟度等级的一套标准,它们几乎包括了所有的IT的企业,只是一些优秀的企业自己内部形成特有的企业管理文化,但是它们并不排斥CMMI和ISO9000模式,甚至还充分肯定CMMI 和ISO9000体系。
5.根据学过的数据库编程经验,举出一个用创建视图的方法进行数据处理的例子。
create view j1_spj
as
select sno,sname,ssex from student
视图(j1_spj)的创建是依据基本表(student)进行查询。当基本表的记录符合条件语句where sno = ‘s1’规定的条件时,就能查询出基本表中符合条件记录的学号、姓名、性别的值。
软件生存周期及开发模型
6.简述瀑布模型、增量模型、迭代模型、原型模型的优点和缺点。
答案如表:
7.软件公司的ISO9000或CMMI管理体系与软件开发模型有关吗?为什么?
无关。因为ISO9000或CMMI管理体系是一种过程与质量管理模型,它是适应于任何软件开发模型的,或者说它与任何开发模型无关。开发模型本身只是规定了软件生存周期中的若干步骤或阶段,便于开发
人员去开发与维护,它并没有规定管理人员的过程管理方法与任务。为此,ISO9000或CMMI管理体系规定采取阶段评审和不符合项的动态跟踪制度,只有前一阶段的不符合项全部改正后,才允许开发人员进入后一阶段的工作。
所谓不符合项,就是在评审中发现的问题项,它与BUG既有联系,又有区别。对于这些不符合项,软件管理部门要列出表格,记录在案,确定负责人,限定改正时间,动态跟踪到底。
8.对生存周期模型裁减指南有什么看法?
“生存周期模型裁减指南”是IT企业或软件组织内部根据软件开发模型的普遍原则,结合本单位的开发经验和行业特点的具体实际定制出来的。它有针对性地对选定的软件开发模型中定义的生存周期,进行恰当地裁减。所谓裁减,就是队员模型中定义的内容进行增、改、删,去掉对本单位或者本项目不适合的部分,增加对本单元或者本项目适用的内容,同时进一步细化。这样可以缩短开发时间,减少开发成本,具有非常现实的意义。
软件立项与合同
9.什么叫风险分析?技能风险和技术风险有何区别?
这里的风险分析是指软件立项过程中对产品开发、销售等可能出现的风险进行分析。分析方法是将一个
大风险化解为多个小风险,然后再一个个克服小风险。
技术风险是指采用新技术的风险程度。技能风险是指项目组成员掌握新技术的风险程度。两者的区别在于一个是说新技术(如新的开发工具,新的设计思想)本身的风险,一个是说人员要掌握这种新技术的风险。
10.行业领域业务专家与产品经理有何异同?
行业领域业务专家是精通某行业领域业务的人,在讲标时能把投标书的内容准确、生动地表述出来,使客户心服口服。而产品经理是某产品需求分析和概要设计的经理或专家,主要负责产品的立项、需求、设计和销售等业务。两者的相同点是:必须精通该产品的功能、性能和接口。不同点是:前者突出熟悉产品的应用业务领域,后者突出熟悉产品的需求与设计。
软件需求
11.需求分析的目的是什么?需求分析的难点在哪里?
软件需求分析,其目的是用于说明软件产品或软件项目需要满足的条件和限制。在软件工程项目中首先要获取用户的需求,通过对软件需要的提取、分析、文档化及验证,为进一步的设计和实现提供依据。
需求分析的难点是:在系统的功能、性能和接口方面,开发者与客户达成完全一致的需求,让客户最终签字确认,并保证在项目验收前,需求相对稳定不变。万一需求有一点变化,双方必须履行“需求变更管理程序”,而变更管理程序在签订合同时已经做了规定。要知道,合同是具有法律效力的。
12.为什么说需求分析是面向流程的?
系统的功能、性能、接口、界面都是在流程中动态实时的反映出来。在所有的流程(物流、人流、资金流、信息流、单据流、报表流、数据流)中,数据流最重要,也最具有代表性。因为在计算机网络系统内,一切流程都表现为数据流,或者说是数据流在不同方向的投影。而流程是动态的、实时的。所以说,需求分析是面向流程的。
13.需求分析的基本思路是什么?
需求分析的思路,是从客户的功能需求(系统需要做什么)出发,由系统的业务流程和数据流程导出系统的业务模型和功能模型,识别出系统的元数据和中间数据,为今后设计数据模型做好充分准备。同时,对系统的软、硬件环境配置,开发工具,开发周期,费用,开发进度,培训,系统风险进行评估。
14.业界存在哪三种需求分析方法?你认为哪一种更好?
业界存在三种需求分析方法:面向功能分析、面向对象分析、面向数据分析。
以上这三种方法,各自适用于不同的目标系统。目前时尚的方法是面向对象分析,包括面向主体和面向方法。总的来说,对于系统软件和应用软件来说,面向功能需求分析的方法简单明了,而面向对象的需求分析方法则复杂抽象。对于以关系数据库为平台的信息系统软件来说,面向数据需求分析方法的特点是抓住了本质。但是,这三种分析方法都离不开面向流程分析这根总线:功能、对象、数据都是在流程中产生的,又都是为流程服务的。
15.需求管理过程的目标和内容是什么?
需求管理的目标,是保证软件项目或产品满足客户在软件功能、性能、接口三个方面的需求。
需求管理过程的内容,主要包括需求确认、需求评审、需求追踪和需求变更活动管理。
16.为什么需求文档要进行同行评审?
同行评审,是软件工作产品验证的活动,其目的是为了及早和高效地从软件工作产品中识别并消除缺陷。重点在于发现软件工作产品中的缺陷。另外,由于进行同行评审,使大量人员对软件系统中原本不熟悉的部分更加了解,因此同行评审还提高了项目的连续性,培训了后备人员。
17.怎么理解不符合项?为什么要对它进行跟踪管理?
不符合项是指没有满足要求的项,不一定是错误,跟bug是不同的。
跟踪的意思在于,获得需求目前的实现状态,确保用户所有的需求都得到满足。可靠的
跟踪信息可为需求变更、系统维护、关键成员离开、系统再设计和类似系统设计等很多方面,提供参考和指导,并可以减少风险和提高项目成功率。
18.需求描述有哪几种工具?你喜欢哪一种?为什么?
需求描述工具包括数据流图、业务流程图、用况图、时序图、用户交互图、数据模型图和功能需求列表、性能需求列表、接口需求列表、界面需求列表等。
选择哪一种描述工具,主要取决于问题域的本质特征。不同的软件,对分析要求的严格程度不同。
我喜欢业务流程图,它包括了物流、资金流、信息流,即业务操作模型,重点是业务操作的流水步骤。业务模型表示了与系统有关的人、设备、其他子系统之间的业务关系和费用关系,它是经过业务流程重组、再创和优化后,并且得到企业领导确认的业务流程图。绘制这个图的工具可以是Office办公软件。
软件策划
19.简述软件策划的步骤。
软件策划共分4个步骤,如表:
20.软件策划要实现的具体目标是什么?
软件策划是项目跟踪和监控的基础,是项目经理和高层经理管理项目的依据。软件策划要实现的具体目标有三个。
1.对供项目测试和跟踪用的三个软件估计已建立文档。这三个评估是:
工作产品规模估计
工作量及成本估计
计算机资源估计
2.软件项目活动和约定是有计划的,并已建立文档。这里的活动,包括开发活动和管理活动。这里的约定,是指对项目的各种标准、规范、规程的约束。
数据库是软件吗
3.受影响的组和个人,同意他们对软件项目的约定。受影响的组和个人有: 软件工程组(项目组)
软件估计组
系统测试组
质量保证组
配置管理组
合同管理组
文档支持组
其中有的组可能只有一个人
21.定义软件过程的含义是什么?
所谓定义软件过程,就是根据选定的生存周期模型,规定软件的开发阶段,及每一阶段的工作步骤和文档标准等内容。
22.项目跟踪与监督的基础是什么?
在项目策划阶段,要为开发计划制定严格的评审流程。开发计划在经过组织批准生效后,将成为进行项目跟踪与监督的基础。
23.软件开发计划书应该包括哪些内容?
《软件开发计划书》是软件策划的输出文档,它包括如下10各方面的内容:
1.软件项目组的目的、范围、目标和对象。
2.软件生存周期的选择与裁减。
3.确定软件开发和维护的规范、方法和标准。
4.软件工作产品的确定。
5.对工作产品规模的估计。
6.对工作量和成本的估计。
7.关键计算机资源的估计和使用情况。
8.项目的进度、里程碑和评审计划。
9.风险的识别和评估。
10.项目工程设计和工具的计划。
24.怎样理解软件中的度量,它有何作用?
软件中的度量,是指对大量测量数据的统计分析。度量是按规定在项目进行过程中,需要采集的度量数据,以便量化地反映项目的进展情况,为管理者提供对项目进展的适当的可视性,同时度量数据是项目过程改善的基础数据,它们存放在测量数据库中。
软件设计
25.软件设计的输入/输出是什么?
对于签订合同的项目,软件设计的输入是《用户需求报告》/《需求规格说明书》,输出是《概要设计说
明书》和《详细设计说明书》。
对于立项的项目,软件设计的输入是《需求规格说明书》,输出是《概要设计说明书》和《详细设计说明书》。
26.概要设计说明书和详细设计说明书有和区别?
《概要设计说明书》,一是要覆盖《需求规格说明书》的全部内容,二是要作为指导详细设计的依据。它注重框架上的设计,它是软件系统的总体结构设计、全局数据库(包括数据结构)设计、外部接口设计、功能部件分配设计、部件之间的内部接口设计,它要覆盖需求规格说明书中的功能点列表、性能点列表,接口列表。
《详细设计说明书》,一是要覆盖概要设计说明书的全部内容,二是要作为指导程序设计的依据,它注重微观上和框架内的设计,它是各子系统的公用部件实现设计、专用部件实现设计、存储过程实现设计、触发器实现设计、外部接口实现设计、部门角授权设计和其他详细设计等。
两者的设计者不同,在一般情况下,《概要设计说明书》是由系统设计师负责,《详细设计说明书》则是由高级程序员负责。
软件建模
27.请简述UML的宏观建模思想和微观思想。
UML的宏观建模思想是:以“9个模型”和“5张视图”为纲,以“9种图”为目,建立系统的UML模型。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。