软件工程生命周期PPT课件
3) 最后,由专家、用户负责人、软件开发和管理人 员组成的软件评审小组要对软件验收测试报告、 测试结果和软件进行评审,通过后,软件产品正 式通过验收(即完成了开发合同),可以交付用 户使用了。
运行
✓ 软件工程师将所开发的软件安装在用户需要的运
行环境中,以交给用户使用,这个阶段成为运行 阶段。
✓ 该阶段的问题是“软件能否顺利的为用户进行服
2) 途径:可以采用结构化的设计方法,采用结构化 的程序流程图、N-S图、PAD图、过程设计语言 (PDL,Procedure Design Language)等工 具进行描述,也可以采用面向对象的设计方法等 等。
3) 阶段成果:应提供“详细设计规格说明”和单元 测试计划等详细设计文档。
编码与单元测试
务”。
“软件的运行是软件产品发挥社会和经济效益的 重要时期”
编码与单元测试
2)单元测试:每编写出一个程序模块的源程 序,调试通过后,即对该模块进行测试,这 称为单元测试。
3)实现阶段的成果:
✓ 按一定规则存储在一定载体上的通过
单元测试的各功能模块的集合;
✓ 详细的单元测试报告等文档。
测试
▪ 测试阶段解决的主要问题是“通过怎样的测
试(及相应的调试),使软件系统达到用户 的预期要求。”
可行性论证包括经济可行性、技术可行性、操作 可行性、法律可行性等。
需求分析
1) 需求分析的任务
需求分析的任务是确定待开发的软件系统 “做什么,不做什么”。不考虑“怎样做”
具体任务包括确定软件系统的功能需求、性 能需求和运行环境约束,编制软件需求规格 说明书、软件系统的验收测试准则和初步的 用户手册。
概要设计
2)实现途径 选择某种方法和工具。设计的软件系统应具有良 好的总体结构、尽量降低模块接口的复杂度,并 力争做到各功能模块之间的低耦合度、而功能模 块内部具有较高的内聚度。
3)阶段性成果 概要设计说明书、 数据库或数据结构说明书、 组装测试计划等文档。
详细设计
1) 任务:是将概要设计产生的功能模块进一步细化, 形成可编程的程序模块,然后设计程序模块的内 部细节,包括算法、数据结构以及各程序模块间 的接口信息,并设计模块的单元测试计划。
▪ 测试分模块测试、集成测试、验收测试。
(1)集成测试
1) 集成测试:根据概要设计提供的软件结构、各功 能模块的说明和集成测试计划,把经过单元测试 检验的模块按照某种选定的策略逐步进行组装和 测试。
2) 主要任务:测试系统各模块间的连接是否正确, 系统或子系统的正确处理能力、容错能力、输入/ 输出处理是否达到要求。
软件开发
软件开发过程由概要设计、详细设计、编码与单 元测试、(综合)测试共5个阶段组成。
开发者通常可提出多种设计方案,并对各种方案 在功能、性能、成本、进度等方面进行比较和折 衷,从中选出一种“最佳方案”。
概要设计
1)任务:
是对需求规格说明中提供的软件系统逻辑 模型进行进一步的分解,从而建立软件系统 的总体结构和各子系统之间、各模块之间的 关系,定义各子系统接口界面和各功能模块 的接口,设计全局数据库或数据结构,规定 设计约束,制定组装测试计划,进而给出每 个功能模块的功能描述、全局数据定义和外 部文件定义等。
3) 阶段成果: ✓ 应是满足概要设计要求、可运行 的软件系统和源程序清单;
✓ 集成测试报告等文档。
(2)验收测试
1) 任务:按照验收测试计划和准则对软件系统进行 测试,看其是否达到了需求规格说明中定义的全 部功能和性能等方面的需求。
2) 验收测试结束时,应生成验收测试报告、项目开 发总结报告,并向用户提交源程序清单、最终用 户手册、操作手册等文档资料。
软件工程
--软件生命周期
内容提要
软件生命周期 软件过程的基本活动
➢软件描述 ➢软件设计与实现 ➢软件有效性验证 ➢软件进化
软件生命周期
软件从定义开始,经过开发、使用和维 护,直到最终退役的全过程称为软件生 存周期。
软件生命周期由软件定义、软件开发、 运行、维护及退役五个时期。而每个时 期又可以进一步划分成若干阶段。
1) 编码的主要任务是根据详细设计规格说明,用某 种选定的程序设计语言把详细设计的结果转化为 机器可运行的源程序模块,这是一个编程和调试 程序的过程。
2) 一般来说,对软件系统所采用的分析方法、设 计方法、编程方法以及所选用的程序设计语言应 尽可能保持一致。
3) 编码阶段应注意遵循编程标准、养成良好的编 程风格,以便编写出正确的便于理解、调试和维 护的程序模块。
需求分析
2)需求分析的实现途径
软件系统需求一般由用户提出。系统分析员和开 发人员在需求分析阶段必须与用户反复讨论、协 商,充分交流信息,并用某种方法和工具构建软 件系统的逻辑模型。为了使开发方与用户对待开 发软件系统达成一致的理解,必须建立相应的需 求文档。有时对大型、复杂的软件系统的主要功 能、接口、人机界面等还要进行模拟或建造原型, 以便向用户和开发方展示待开发软件系统的主要 特征。确定软件需求的过程有时需要反复多次, 最终得到用户和开发者的确认。
问题定义
“要解决什么问题?”
“尽管确切定义问题的必要性是十分明显的,但 在实践中它却可能是最容易被忽视的问题” 通过对客户的访问调查,系统分析员扼要的写 出问题的性质、工程目标和工程规模的书面报 告,经过讨论和必要的修改后这份报做”
本阶段的任务是根据用户提出的工程项目的性 质、目标和规模,进一步了解用户的要求及现有的环 境及条件,从技术、经济和社会等多方面研究并论证 该项目的可行性,即该项目是否值得去解决,是否存 在可行的解决办法。
需求分析
3)需求分析的阶段成果
需求分析阶段的主要成果有软件需求规格说明、 软件验收测试计划和准则、初步的用户手册等。
软 件 需 求 规 格 说 明 ( Software Requirements Specification,即SRS),是一个关键性的文档。 多数场合,面向开发者的软件需求用需求规格说明语 言来描述,它是软件开发人员进行软件设计的依据; 另一方面,从某种意义上讲,SRS又起到与用户签定合 同的合同书的作用。