思步网
标题:
一次迭代式开发的研究-6:功能的优先级评估
[打印本页]
作者:
delia2010
时间:
2013-5-7 13:01
标题:
一次迭代式开发的研究-6:功能的优先级评估
本帖最后由 delia2010 于 2013-5-11 08:52 编辑
一次迭代式开发的研究:功能的优先级评估
前面我们提到,迭代式开发最重要的两项前期分析就是工作量评估和优先级评估。工作量评估不仅能够确定整个项目的开发周期、成本预算,而且能够确定每项工作的开发周期,为工作的时间分配提供了依据。
但是,如此多的工作,谁先做谁后做,如何安排它们的先后顺序,则是由工作优先级来决定的。
迭代式开发的特点就是持续集成,也就是首先开发最重要、最基本的功能,而暂时忽略掉分支的、次要的功能。正因为如此,迭代式开发需求将优先级最高的功能放到前面最先完成,然后安排次优先级的,依此类推。总之,优先级评估决定了迭代式开发的工作安排。
那么,如何决定每个功能,每项工作的优先级呢?其决定因此很多,但通常来说,有两个因素是最基本的:是否靠近主营业务,以及用户使用是否频繁。
一个组织想上线一套管理系统,我们首先要分析它的主营业务。一个医院的主营业务是门诊系统,一个ERP的主营业务是进销存。越靠近这些主营业务的功能优先级越高。
同时,我们在需求分析过程中还应考察用户对各项功能的使用频率。一般来说,一个事物处理系统中,完成各项业务操作的功能必然使用频率最高,对各项业务操作的查询次之,而那些各种各样的统计分析报表则是频率最低的。频率高的功能优先级高,频率低的功能优先级低。
当然,决定优先级的因素还有很多,比如每项功能的成本与收益、紧急程度、战略意义等。我们可以绘制一个优先级表,一边罗列出所有影响因素,一边罗列出所有的功能,一项一项地分析,最终综合评估各项功能的优先级。
优先级评估的最重要的作用就是排列各项功能的开发先后顺序。前面我们提到,迭代式开发的最大特点就是迭代。整个软件开发过程被划分为数个迭代期,每个迭代期结束时应当提交一份可独立运行的程序,向用户演示。按照这样的思路,当软件开发第一个迭代期结束的时候,我们提交的是一套完整的程序,只是不够健壮,操作不方便,没有那些辅助的、次要的功能而已。这些剩余的功能,我们将在之后的迭代期逐渐完成。
根据这样的思路我们就明白了为什么我们需要进行优先级评估。将主营业务的、使用频繁的功能首先开发出来。在开发时,也主要考虑主流程而忽略分支流程。经过第一次迭代,一个可运行的、主要功能都有的软件雏形就出来了。之后,再在此基础上继续丰富、完善,直到整个项目的完成。
icon_logo.png
(3.33 KB, 下载次数: 2)
下载附件
保存到相册
2013-6-18 05:13 上传
该贴已经同步到
delia2010的微博
作者:
牛哄哄
时间:
2013-5-9 11:53
收藏起来。
作者:
hacrxy99
时间:
2013-5-30 16:03
以我的经验来看,楼主的想法是可以执行的~
作者:
kingki0011
时间:
2013-6-17 20:43
看了LZ的帖子,我只想说一句很好很强大!
作者:
太阳雪下
时间:
2013-6-18 09:03
看帖看完了至少要顶一下哦~
作者:
红酥手
时间:
2014-5-27 09:31
学习下我只是路过,不发表意见……
作者:
。收纳空白
时间:
2014-7-16 20:01
非常好,顶一下占位编辑
作者:
枫林火山
时间:
2014-7-19 11:24
我是个凑数的。。。
作者:
包容的爱
时间:
2014-8-6 17:11
我是个凑数的。。。
作者:
渐渐习惯了
时间:
2014-11-11 15:08
我是个凑数的。。。
作者:
永杰同心
时间:
2015-2-3 15:43
向楼主学习
作者:
带着紫
时间:
2018-5-4 08:24
有空一起交流一下。
作者:
片片
时间:
2018-9-10 10:57
看起来好像不错的样子
作者:
笑渣渣i
时间:
2021-8-12 16:48
我也来顶一下..
欢迎光临 思步网 (http://www.step365.com/)
Powered by Discuz! X3.2