内容发布更新时间 : 2024/11/8 3:45:31星期一 下面是文章的全部内容请认真阅读。
《软件工程》课程要点
? 每章教学课件中的“本章小结”列出了需要掌握的内容 ? 教学过程中的例题和习题也是课程重点
一、软件工程与软件过程概述
1.概念:
(1)软件的概念(组成成分、作用);
答:计算机软件是程序、数据和相关文档的集合;用于实现计算机系统所需要的逻辑方法和控制过程
(2)软件危机的含义、表现、产生原因(客观、主观)
答:计算机软件开发和维护过程中遇到的一系列严重问题。 软件危机的表现:
①对软件开发成本和进度的估计很不准确 ②已完成的软件不能满足用户需求 ③软件质量差 ④软件不可维护
⑤软件没有开发文档
⑥软件成本在计算机系统总成本中所占的比例逐年上升 ⑦软件生产率跟不上硬件的发展和计算机迅速普及的趋势 与软件的特点有关(客观原因):
①软件是计算机系统中的逻辑部件,缺乏“可见性”, 管理和控制软件开发过程相当困难
②软件在使用期间不存在机械磨损和老化问题,一旦 发现错误,通常意味着修改原来的设计,因此软件 难维护
③软件规模庞大,程序复杂性增加,需多人分工合作(不 能保证每个人完成的工作合在一起构成一个高质量的大 型软件系统)
与软件开发和维护的方法不正确有关(主观原因): ① 开发无计划
② 忽视软件需求分析的重要性 ③ 轻视软件维护 ④ 无过硬评测手段
⑤ 缺乏有力的开发方法和工具 ⑥ 不重视开发文档等软件配置
(3)软件工程学科包括的内容(三要素)、解决的主要问题 答:(1)软件工程定义:
1) 软件工程是指导计算机软件开发和维护的工程学科 2) 采用工程化的概念、原理、技术和方法来开发和维护软件3)将经过时间考验而证明正确的管理技术和开发技术结合起来,以较经济的手段开发出高质量的软件并有效维护它
2)软件工程方法学的三要素:
①方法:完成软件开发各项任务的技术方法
1
②工具:为方法的高效运用,而提供的自动或半自动的软件支撑环境 ③过程:为了获得高质量的软件所需要完成的一系列任务的框架,它规定了完成各项任务的工作步骤
(4)软件生命周期的含义、组成阶段及各阶段主要任务
答:软件生命周期:
一个软件从定义、开发、运行维护 ,直到最终被废弃要经历一个漫长的时期,这个时期称为软件生命周期。
(1)问题定义阶段:
通过调研,提出关于问题的性质、工程目标和工程规模的书面报告,并且需要得到客户的确认。
●回答“要解决的问题是什么?” ●文档:问题定义报告 (2)可行性研究阶段:
用最小的代价在尽可能短的时间内确定问题是否能够解决。 ① 进一步了解用户需求 ② 提出若干种可能的系统实现方案
③ 分析每种方案的技术、经济、社会可行性 ④ 最终确定这项工程的可行性
●回答“是否有行得通的解决方法?” ●文档:可行性研究报告,项目开发计划 (3)需求分析阶段:
对目标系统提出完整、准确、清晰、具体的要求。 ① 得出经过用户确认的系统需求
② 用正式文档(需求规格说明)准确表达系统需求 回答 “系统必须做什么?” 文档:需求规格说明书 (4)概要设计阶段: ①设计系统实现方案
②设计程序的体系结构,即确定程序由哪些模块 组成以及模块间的关系。 概括地回答“怎样实现目标系统?” 文档:概要设计说明书
5)详细设计阶段:设计实现每个模块功能所需要的算 法和数据结构
回答“应该怎样具体地实现这个系统?” 文档:详细设计说明书 (6)编码和单元测试:
写出正确的、易理解、易维护的程序模块代码; 测试编写出的每一个模块
? 文档:经过测试的程序源代码、
? 程序开发记录(模块开发卷宗)
(7)综合测试阶段:通过各种类型的测试(及相应的调试) 使软件达到预定的要求。
? ①集成测试(组装测试)。
2
? ②验收测试 ? 测试文档:
? 测试计划、详细测试方案、实际测试结果
(8)软件维护阶段:
通过各种必要的维护活动使系统持久地满足 用户的需要。 四类维护活动:
改正性维护、适应性维护、完善性维护、 预防性维护
文档:软件维护申请、软件修改报告
2.需理解的问题:
(1)软件与程序的区别和联系?
答:计算机软件是程序、数据和相关文档的集合; 程序:能够完成特定功能和性能的可执行的指令序列
(2)开发一个软件项目包括哪些基本的步骤?每一步骤完成哪些工作? 答:
(3)主要的软件过程模型(生命周期模型)有哪些?各自有什么特点?
答:软件生命周期模型也称为软件过程模型,它直观地描述了把软件生命周期划分成哪些阶段及各个阶段 的执行顺序
主要有:瀑布模型、增量模型、螺旋模型、喷泉模型、统一软件过程。 (2)瀑布模型的特点
①阶段间具有顺序性和依赖性 ②推迟实现的观点
③阶段质量保证观点(文档驱动)
瀑布模型的优点:强迫采用规范方法开发软件;严格规定了各阶段提交的文档;各阶段结束前必须经过技术审查和管理复审。
瀑布模型缺点:分析和设计阶段只考虑逻辑模型;过分依赖文档,可能导致最终的软件产品不能完全满足用户需求
瀑布模型适用的软件项目:规模小、需求明确、无须维护 2)快速原型模型的优点:
通过原型获得准确的用户需求;通过原型积累了开发经验,软件开发时期的各阶段基本上是线性顺序过程、提高了总开发效率。
快速原型模型适用的软件项目:规模小、需求不够明确、无须维护 3)增量模型的优点:
①便于并行完成开发工作;②逐步提交软件产品; ③软件的可维护性和可扩充性较好
增量模型适用的软件项目:强调开发进度、可维护性要求高、可扩充性要求高
螺旋模型是一个演化的软件过程模型,是在每个阶段之 前都增加了风险分析过程的快速原型模型。
在螺旋模型中,螺旋线的每个周期对应一个软件生命周 期的开发阶段。每个阶段包括四个方面的活动: ①制定计划-确定目标,选定方案,设定约束条件
3
②风险评估-评估所选方案,识别风险,考虑如何消除风险 ③实施工程
④评估工程-评价开发工作,提出修正建议。
使用螺旋模型需要丰富的风险评估经验和专门知识; 螺旋模型适用于内部开发的大型软件项目 1、喷泉模型也称为面向对象的生命周期模型 2、软件开发过程阶段之间是迭代的、无间隙的
对象概念贯穿整个开发过程,只用对象类及其关系表达分析、设计、实现等活动
在分析、设计和编码等开发活动之间并不存在明显的边界,开发各阶段同步进行、可以提高开发效率
3、各开发阶段重叠、可能随时增加新的需求和各种信息,
因此喷泉模型要求严格管理文档,审核难度加大,对项目管理要求较高。
RUP首先建立整个项目的不同时间阶段,体现开发过程的动态结构,包括:初始阶段、细化阶段、构造阶段、移交阶段。 同时以内容来组织项目的活动,体现开发过程的静态结构。 RUP融入了瀑布模型的线性结构和演化模型的增量及迭代思想
(3)有哪些主流的软件工程方法?
答:①传统方法学(生命周期方法、结构化方法):
●从时间角度对软件问题进行分解,将软件开发维护过程划分成若干阶段。 ②面向对象方法学:
面向对象方法学的出发点和基本原则:尽量模拟人类习惯的思维方式,使开发软件的方法与 过程尽可能接近人类认识世界解决问题的方法与过程,使问题空间与实现空间在结构上尽可能一致。
(4)如何消除软件危机(如何解决软件危机?)
一、概念:软件过程,软件生命周期,软件生命周期模型 6、具体说明:针对不同的软件项目,应该如何选择软件生 命周期模型 7、你如何理解RUP的特点 8、敏捷过程的主要特点和优势 1.什么是软件生命周期,分哪几个阶段、各阶段的任务是 什么? 2.常用的软件生命周期模型有哪些?总结它们的特点。 3.谈谈下列三者之间的区别和联系: 软件工程、软件过程、软件生命周期模型
二、结构化分析-面向数据流的分析方法
1.什么是软件需求?需求分析过程(步骤)?
答:软件需求:软件系统必须符合的条件和具备的功能
4
需求分析的任务(过程):
1.准确了解用户情况和需要解决的问题:
◆与用户沟通的途径:访谈、参考类似系统、快速原型技术 2.对需求反复求精和细化,得出对目标系统完整、准确 和具体的要求
3.需求建模:对获得的需求做出抽象、即进行无歧义描述。
◆模型是为了理解事物而对事物做出的一种抽象,是对事物的一种 无歧义的书面描述。 4.编制需求规格说明书 5.进行需求分析的评审
2.需求分析模型:
(1)功能模型(数据流图DFD)的含义、描述符号、画法步骤及规则 (2)数据模型(E-R图)的作用
(3)行为模型(状态转换图)的作用 (4)数据字典的作用
三、结构化设计
1. 软件设计的任务? 结构化设计与结构化分析的区别和联系? 2. 软件设计遵循的基本原理及规则:
(1)模块化的含义、如何划分模块(降低成本、提高独立性)? (2)抽象与逐步求精的含义、二者间关系如何? (3)信息隐藏的含义
(4)如何完善软件结构(深度、宽度、扇入、扇出、作用域、控制域)? 3. 模块独立性:
(1)模块独立性含义?
(2)模块独立性的度量标准:耦合的分类、含义及应用;内聚的分类、含义及应用。 4. 概要设计(面向数据流的设计方法) (1) 概要设计的任务?
(2)数据流图的类型及特征(变换型、事务型) (3)变换分析设计方法的应用(步骤) (4)事务分析设计方法的应用(步骤) 4.详细设计(过程设计)
(1)详细设计的任务
(2)结构化程序(设计)的特征
(3)详细设计结果的描述工具:程序流程图、N-S图、PAD图、PDL、判定表 一、理解以下问题:
1、什么是软件需求?软件需求如何分类? 2、需求分析的作用和重要性 3、需求分析阶段需要完成的工作 4、结构化分析模型的内容
5、E-R图的内容和作用;数据流图的内容和作用;
状态转换图的内容和作用;数据字典的内容和作用
5