敏捷开发是快速迭代,快速交付的开发模式。这也就要求迭代周期内任务量不宜过大,以保证在预期内能够按时完成开发计划。
敏捷开发中怎样保证开发任务的适宜呢?答案是任务分解。而任务分解的前提则是需求确认。
敏捷开发中的需求确认
我们都知道需求的来源渠道很多(如用户调查问卷,用户访谈,客户服务人员/商务人员的反馈,产品的技术交流群,用户使用数据分析等,甚至还有一部分来源于产品经理对产品的定义,以及对技术的把握和对竞品的分析),通常产品经理收集到的用户故事需要经过分析筛选整理,形成最初的产品需求。此时的产品需求算是草稿状态的产品需求。
产品经理通过发布计划会议对初步的产品需求进行讲解传达,由敏捷团队讨论细化,对其评估和排序之后形成需求条目,也就是可以排到敏捷开发计划里面去实现的需求列表。至此为需求确认的完成阶段。
需要注意的是,在需求分解时需要面对的一个问题是需求的优先级问题。先做哪个后做哪个?你可以参考下面几个标准。
1、价值,包括对产品自身的价值和对用户的价值,价值越高优先级越高。
2、必要性,先做必需的功能特性,然后再做其他高级特性。
3、紧迫性,时间要求越高的优先级越高,特别是线上问题的解决。
除了优先级问题,在敏捷开发中我们还需要面对需求变更问题。需求变更之所以可怕,主要是因为变更影响的范围无法预估。在传统项目管理中,由于没有有力工具的支撑,产品经理在变更需求的时候,无法知晓该需求的影响范围,也就很被动。
而如今的项目管理工具已经很好的解决了这个问题,像禅道就是将需求、任务、bug和用例都纳入为一体管理,就可以很清楚的知晓变更的影响范围,从而给产品经理更好的指导。虽然敏捷开发最大的优势是拥抱变化。但这并不意味着需求想变就变,产品经理还是要尽量控制变更情况的发生。
需求确认后就进入为需求分解任务阶段。如何为需求分解任务呢?
敏捷开发的特性决定了迭代内任务量要适宜。任务量太大导致项目延期,任务量太小则工作量不饱和。所以需求的分解过程是一个对资源的评估再分配过程(这里的资源一般是指团队的开发能力,包括人员、任务量、工时等的合理统筹)。
需求分解在敏捷开发中一般通过迭代计划会议实现。敏捷团队对每一个需求进行分解,分解的标准是完成该需求(stroy)的所有任务,最终实现每个任务都有明确的负责人。敏捷开发中需求分解的目的在于将需求细化为可执行可评估的开发任务。
我们常用的管理软件禅道中这个过程就表现为“为需求分解任务”。研发团队对需求进行详细的评估和细分,生成完成这个迭代内的所有任务(这里的所有任务,包括但不限于设计,开发,测试等),团队成员领取任务,并进行工时的估计。
在具体操作上表现为通过创建任务,关联相应的需求来实现。在禅道的项目需求列表页面,可以方便的对某一个需求进行任务分解,同时还可以查看这个需求已经分解的任务数,指派的成员等(动态演示地址:http://www.zentao.net/book/zentaopmshelp/130.html)。
分解任务的注意事项
1、需要将所有的任务都分解出来。这里面包括设计,开发,测试,美工,甚至包括购买机器,部署测试环境等等。
2、任务分解的粒度越小越好,尽量控制在几个小时就可以完成。
3、如果一个任务需要多个人负责,继续考虑将其拆分。
4、任务应做到相对独立完整,某个任务的延期不至于影响到其他任务的进行。
5、多个子任务要进行排序,要区分轻重缓急。
6、任务的分配最好是自由领取,这样可以大程度上调动大家的积极性。
说到底,任务分解是敏捷开发管理中不可或缺的基本流程,任务分解的作用就在于将需求转变为可量化可执行的具体工作内容。同时敏捷团队也可以做到心中有数,项目经理更好的掌握研发进度,随时调整,以保证按时交付。因此,任务分解的实现使得敏捷开发得以更好的实现。
相关推荐
### Tomcat全攻略--经验之谈 #### 一、简介 Tomcat作为一款开源的Servlet容器,自问世以来便受到了广泛的关注与应用。它不仅是Jakarta项目中的一个重要组成部分,还曾荣获JavaWorld杂志颁发的“2001年度最具创新...
学习过ARM的人经验之谈,对正在学习ARM的人有个正确的规划
“嵌入式开发的工程师经验之谈----(新手必看)” 本文通过一个嵌入式开发的工程师经验之谈,侧面生动详细的为正在学习嵌入式的读者提供学习帮助,希望对读者有所帮助。下面是该文中的知识点总结: 一、嵌入式系统...
"挺进嵌入式----来自多年嵌入式开发工程师的经验之谈" 嵌入式专业是一门实践性非常强的学科,只有多动手,多实践,多编程,多调试,多看书,多思考才能真正掌握好嵌入式开发技术。这门学科涉及知识面非常广泛,包括...
1. 布局规划(Layout Planning):布局应考虑信号路径、热管理、EMI抑制等因素。关键组件应靠近,高频率信号和低频率信号应分开布线,电源和地线应尽可能短且宽。 2. 布线策略(Routing Strategy):高速信号通常...
### iPhone入门开发经验之谈 #### 1. Objective-C概述 Objective-C是一种强大的面向对象的编程语言,由Brad Cox在20世纪80年代发明,旨在结合C语言的强大功能和Smalltalk语言的优雅特性。Objective-C是C语言的一个...
### 技术分享:开关电源PCB设计经验之谈——et EDRH-B-4 贴片共模电感(大电流) 系列 #### 关键知识点概述 本技术分享主要围绕开关电源PCB设计中的关键组件——ET EDRH-B-4系列贴片共模电感进行详细讲解。该系列...
根据提供的文件信息,本文将重点围绕“项目管理经验之谈”这一主题展开,提炼出关键的知识点,并结合标题、描述及部分内容进行详细解读。 ### 项目管理的核心要素 #### 一、需求管理的重要性 1. **需求理解与确认...
一个过来人学新概念英语的经验之谈-新概念英语自学经验.doc
「安全教育」基于Splunk的安全监控系统_企业SIEM经验之谈 - APT攻击 NGFW 日志审计 信息安全 安全众测 防火墙
项目管理经验之谈.docx
### WEB开发框架选取经验分享 #### 一、引言 在IT行业的快速发展中,Web开发技术不断迭代更新,为了满足日益增长的业务需求和技术挑战,选择合适的开发框架至关重要。本文作者通过亲身经历,深入探讨了一套开发...
java安全开发规范-经验之谈 java开发过程中的web网络安全,java代码安全,数据库安全
在电子设计领域,AutoDesk Altium Designer(简称AD)是一款广泛使用的PCB设计软件。本文将分享一些提高AD绘图效率和处理特殊情况的技巧,以及如何选择正确的阻抗计算工具Polar Si9000。 首先,对于高密度板的设计...
"架构师有话对你说——软件开发经验之谈"这篇文档,无疑是对这个重要职位的深入洞察和经验分享。下面,我们将根据标题和描述中的线索,探讨一些关键的软件开发知识点。 首先,架构师的角色并不仅仅是画出漂亮的图表...
网吧网管安装维护经验分享; 对于新手网管相当有用。 分享下。。。
"项目开发设计模板"集合了著名软件设计师的经验之谈,为开发者提供了一套完整的项目管理框架,帮助我们规范流程,提高开发效率。以下是根据这个模板可能涵盖的一些关键知识点: 1. **需求分析**:这是项目开发的第...
系统集成项目管理工程师中高级一次通过经验之谈-附件资源