软件生命周期及研发模型
软件生命周期
- 什么是软件生命周期
软件开发全部过程、活动和任务的结构框架,是从可行性研究到需求分析、软件设计、编码、测试、软件发布维护的过程。 - 软件生命周期的三个时期
1. 软件定义
(1)问题定义——要解决的问题是什么
(2)可行性研究——上一阶段所确定的问题是否有行得通的解决办法
(3)需求分析——目标系统必须做什么
2. 软件开发
(1)概要设计——怎样实现目标系统
(2)详细设计——应该怎样具体地实现这个系统
(3)编码和单元测试——写出正确的容易理解、容易维护的程序模块
(4)综合测试——通过各种类型的测试使软件达到预定的要求
3. 运行维护
使软件持久地满足用户的需要 - 软件研发模型
1. 大爆炸模式
特点:简单,计划、进度安排和正规开发过程几乎没有,所有精力都花在开发软件和编写代码上,没有测试活动
2. 边写边改模式
特点:开发组最初有粗略的想法,进行简单的设计,然后
开始漫长的来回编写、测试和修改缺陷的过程。适合快速制作而且用完就扔的小项目,例如,原型范例和演示程序 - 软件研发模型——瀑布模型
1. 软件生命周期的瀑布模型
2. 瀑布模型的特点
(1)瀑布模型非常强调产品的定义:开发或者代码编制阶段只是其中单独的一块
(2)瀑布模型各步骤是分立的\没有交叉
(3)瀑布模型无法回溯:一旦进入某个步骤,就要完成该步骤的任务,然后才能向下继续——无法回溯
(4)每个阶段都要仔细验证,线性过程太理想化,越来越不适合现代软件的开发模式 - 快速原型模型的特点
1. 克服瀑布模型的缺点,更好地满足用户的需求并减少由于软件需求不明确带来的项目开发风险
2. 适合预先不能确切定义需求的软件系统的开发
3. 不适合大型系统的开发(适合开发小型的、灵活性高的系统)
4. 前提要有一个展示性的产品原型,因此在一定程度上可能会限制开发人员的创新 - 软件研发模型——螺旋模型
1. 软件生命周期的螺旋模型
2. 螺旋模型的特点
(1)开始不必详细定义所有细节
(2)从小开始,定义重要功能,努力实现
(3)接受反馈,进入下一次循环
(4)测试活动贯穿于每个循环
(5)螺旋模型很大程度上是一种风险驱动的方法体系,因为在每个阶段之前及经常发生的循环之前,都必须首先进行风险评估
(6)在风险较大的项目开发中,如果未能够及时标识风险,势必造成重大损失。过多的迭代次数会增加开发成本,延迟提交时间。 - 软件研发模型——敏捷开发
敏捷开发流程:
(1)产品经理调研客户需求,协商需求的优先级,进行排序
(2)项目经理接收到需求,分配任务,计划研发:迭代任务2-6周一个周期
(3)迭代周期,每日站会(立会),讲述昨天任务完成情况,今日计划安排,遇到什么问题等。参会人员有开发、测试、QA、设计人员等
(4)交付客户进行确认,一个迭代周期结束需要开反思会,避免下个周期出现同样的错误
(5)进入下一个迭代周期…直到交付客户的所有需求,避免了后期出现大量不符合客
户需求的功能