需求是整个软件项目当中最重要一项输入。软件开发和传统生产行业最大的区别在于,需求总是模糊的、主观的和随时变化的。相对于电子产品、汽车等制造行业有形的硬件需求,软件开发的需求的描述和验收是个难以解决的问题。

但是需求又是整个项目能否成功的决定性因素,所以我们必须对需求进行管理,从而使需求成为整个软件工程的基线。使得所有产品、设计、研发、测试、运维工作能围绕着统一的需求开展。保证项目能顺利进行,完成目标。

需求管理的难点?

一般情况下,需求难以管理的原因有以下几方面:

1、需求描述的问题

一般来说,最容易造成开发出来的产品与设计功能不符的原因便是需求描述的问题了。其实大部分情况下,写需求文档的人没有错,看文档的人也没有错。共享文档不等于达成共识。只是因为面对同一段描述,人与人之间的理解不相同,而且这种情况是一定会发生的。所以对于需求,一定要基于团队面对面讨论,保证对需求的理解一致。

2、需求变化的问题

需求变化的原因很多,如一开始没有识别全,新增需求;业务变化导致需求变化;需求有误;需求不清晰等。需求变化将导致从设计方案到编码测试的修改,延迟交付,带来诸多麻烦。这就需要团队在迭代进行前,尽量保证需求清晰明确。

3、需求的优先级及排期问题

什么样的功能能对用户产生最大的价值,这是需求管理中最重要的问题。因为在软件开发中,你想要开发的功能,永远比你能投入的资源多。因此,找到这一部分最有价值的功能,优先处理,尽早交付,才是需求管理的核心所在。

如何对需求进行分级管理?

敏捷开发中,用户故事被广泛使用,但是我认为仅仅使用用户故事是不足以很好的管理整个项目的。(关于用户故事的诸多好处,就不在此多说了。)用户故事可以描述出真正有价值的需求,也能提供优先级和故事点规模为排期提供依据。但是繁多的同级用户故事会让人迷失在其中,只见树木不见森林。每次的交付和发布都会变成功能的东拼西凑,甚至有时候还会为了单个功能的价值,偏离整体的产品愿景。

因此,我们推荐按照 Epic Story - Feature - User Story 的层级顺序去管理需求。团队也可有自己的层级关系定义,取决于团队的喜好。

按照Epic Story-Feature-User Story对需求进行层级划分的好处在于:Epic一级可以与产品战略对齐,Feature一级作为版本发布规划的对象,User Story则进入迭代进行研发。

1. Epic Story

Epic Story即史诗故事,简称为史诗。一般史诗被定义为一个非常大的用户故事,是产品中的主干任务或者公司级战略举措,一般情况下会持续数月。我们对史诗的风险、业务价值、工作量进行评估,得到史诗的优先级,再依据优先级对史诗进行排期。

2. Feature

Feature即特性,特性是能对用户提供价值的完整功能。描述了产品具有的一个完整功能,特性一般也比较大,可能持续数周,横跨几个迭代。一般作为版本发布计划的规划对象。我们依据特性的风险、业务价值、工作量评估特性的优先级,进行版本发布的规划。

3.User Story

User Story即用户故事,用户故事是能对用户提供价值的功能场景。一般来说,特性可以拆分为多个用户故事,每个用户故事都对用户有价值,但是单个用户故事却有可能不能被用户正常使用或者是整个功能的细分场景。我们会对用户故事的故事点进行估算,放入迭代计划中进行开发。

我们是如何管理需求的?

一、需求收集

我们的需求来源主要有四种:

  • 用户反馈给业务线同事的需求。
  • 公司内部同事提出的需求。
  • 用户通过产品内帮助中心-用户声音直接反馈的需求。
  • 产品经理规划的需求。

1、前两种来源的需求都汇总在统一的需求收集项目中,要求提出人以用户故事的形式创建,描述出具体的用户场景。

所有需求反馈都以用户故事的类型创建,由产品经理进行评估。确定采纳的需求建议再进一步分析,依照故事的规模和影响范围决定其属于史诗、特性还是用户故事,在对应项目的需求规划中响应。

2、用户在帮助中心可以提交自己的需求建议,也可以对已有的需求建议或者我们的规划进行点赞,提升其在队列中的排序。

这一部分需求,产品经理会通过后台查看,分析评估之后,考虑在对应项目的需求规划中响应。

二、需求实现

1、产品经理会在对应的项目中按照史诗-特性-用户故事的层级,对整个产品的功能框架进行整体的需求规划。

2、对已规划的需求进行优先级的排序,来确定正在进行中的史诗里,哪些特性需要在接下来的版本进行发布。将其规划入对应版本。

3、将进入发布版本的特性拆分为用户故事,对用户故事进行估算以后,按照迭代容量安排开发计划。

4、进入迭代的用户故事会按迭代周期进行交付,更新特性的进度。特性验收完成后更新所属史诗的进度。由下而上的推进整个产品的开发进度。

通过对不同层级需求在不同维度上进行管理,使得整个需求管理流程更清晰流畅,极大程度的提升了需求管理的效率,聚焦了产品目标。

Worktile官网: https://worktile.com/

作者:Worktile 产品经理 彭东锴
文章首发于「Worktile官方博客」,转载请注明来源。

产品经理如何有效进行需求管理?相关推荐

  1. 产品经理如何进行需求管理?

    文章目录 交付需求 第一步:提交需求 1.流程图 2.结构图 3.原型图 4.产品需求文档 第二步:需求评审 制定需求实施计划 1.和研发确定开发计划 2.和设计人员确定UI设计计划 3.和运营人员确 ...

  2. 产品经理如何做需求管理?掌握这4个方法,让你的项目更高效

    作为产品经理,需求管理是其日常工作中最基本的内容,任何项目的起点,也都是基于需求管理. 需求管理的好坏直接关系到产品的质量和用户的满意度,产品经理需要掌握一定的技能和方法,才能做好需求管理. 如何做需 ...

  3. day3之2020年12月29日产品经理学习之需求管理

    前言 今天是来北京的第四天,学习的第三天,还有一天是自习.等于是上两天自习一天,上三天休一天.对于学习的这些天来说,我每天都很忙碌,我不也不知道自己在忙碌啥.反正没睡好,太冷了老是冷醒然后隔音差,老是 ...

  4. 产品经理如何基于需求迭代产品(下篇3):产品的整体设计之逻辑层和交互层...

    上一篇:产品经理如何基于需求迭代产品(下篇2):产品的整体设计之业务层和系统层 整体设计 逻辑层:实体建模.角色结构.逻辑流程 逻辑层顾名思义,就是逻辑上的东西,是系统和业务的内在逻辑.逻辑明确才能开 ...

  5. 产品经理培训课程:产品经理从专业走向管理

    一.产品经理认识篇 1.产品经理定义 产品经理(Product Manager),通常是指:担负某类产品研发.运营.管理的经理人. 他们的工作纵深从:前期市场调查.产品的创意.策划实施.产品研发.产品 ...

  6. 漫画 | 如何向外行解释产品经理频繁更改需求会令程序员很焦灼?

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 众所周知,程序员是一类思维比较特殊的群体,但他们也有不为人 ...

  7. 产品经理如何做好需求挖掘

    产品经理如何做好需求挖掘 产品经理如何做好需求挖掘 一.什么是需求 产品是用来解决用户的问题的,那么这些问题就是需求 例子:饿了么,解决用户不想出门吃饭,节省吃饭时间的需求 从互联网产品角度出发,需求 ...

  8. 需求ROI评估:B端产品经理怎么做需求优先级排序?

    刨除公司战略性的调整需求,以及线上的紧急bug(影响用户使用核心流程的bug),我们来谈谈B端产品经理可控的需求优先级排序. 围绕着这一切需求的排序,无他,就是ROI的评估,哪个投资回报高,自然先做哪 ...

  9. 产品经理如何基于需求迭代产品(上篇):需求调研的四个步骤

    作者简介: 周文熙老师,携程商业产品经理,多年工作经验, 公众号:vency不二 掘金专栏:https://juejin.im/user/58cb4b612f301e007e3cc287/posts ...

最新文章

  1. 警惕!这7件事情千万不要发生你身上-来自15年程序员的忠告
  2. 关于报工和生产订单的一些状态解释
  3. Java Double类hashCode()方法及示例
  4. 【Java从0到架构师】基本概念 + 环境搭建
  5. postgre 表被加锁无法解锁问题
  6. 定位CoreLocation 使用
  7. duilib绝对定位与相对定位
  8. OTT TV 与 IPTV 的区别
  9. arch linux 看图软件,菠萝看图
  10. Uniapp微信雪糕刺客单页小程序源码
  11. 直观理解积分-从零开始:机器学习的数学原理和算法实践
  12. 20170330今日头条笔试题
  13. 「目标检测算法」连连看:从Faster R-CNN 、 R-FCN 到 FPN
  14. 计算机网络_实验5_集线器与交换机对比
  15. Python量化交易平台开发教程系列7-顶层GUI界面开发(1)
  16. 国庆、中秋双节同庆 青岛浮山湾灯光秀启动节日模式
  17. NGINX源码之:listen和server_name命令与listening监听创建
  18. 使用阿里云OSS完成文件的上传样例
  19. 艾赛克科技《RFID智能仓库管理系统》
  20. Python中关于浮点数运算的不确定尾数的解释

热门文章

  1. java发送邮件将附件变成压缩包_请将实训期间制作的网站打成压缩包以附件形式提交。(含相应的文档资料)...
  2. 基于综合几何特征和概率神经网络的故障诊断(翻译)
  3. Mac新手操作指南(四)
  4. AD将元器件由正面,放置到反面/元器件由反面放到正面
  5. 数据库计算机实验报告总结,计算机软件数据库实验报告.docx
  6. 1、学ARM前必读文章
  7. 在Ubuntu系统上在线下载/删除/查看软件包信息apt命令
  8. 冶金工业概论多媒体辅助教学系统
  9. vue--es6转es5打包
  10. 串口屏-迪文10寸T5串口屏简单上手