转载自:http://blog.csdn.net/cheny_com/article/details/6587277
本文是“松结对编程”系列的第三篇。(之一,之二,之三,之四,之五,之六,之七,之八,此系列之九及之后文章请见栏目总目录。)
估算是经久不衰的管理话题,大致分为两种流派。
第一种是领导指派,领导说这是10天的活,就必须当是10天的活来干,如果干不完,可以用加班、损失质量、功能缩水等各种方法曲线救场。另一个变种是大家自己估算,但是交给领导审批;领导审批其实就是砍一半的过程,还好大家之前就已经加了一倍,所以不怕。
第二种是自我管理派(偏敏捷),就是由具体开发的人员自己说开发工作量,领导和他人不干预。尽管“自组织”了,但是领导深以为这种方法留下了偷懒的种子,而队员也觉得某人的估算很不靠谱(太长或太短),到底怎么办呢?
共同估算吧。
--------------------------------------------
基本概念
假设现在是一个计划会上,PO(产品经理,策划组长,项目经理,某销售……)刚刚讲完需求,下一步不是交给某人做估算,而是交给某个潜在的组(师傅+1~3徒弟)。
由师傅带头打牌,对,在计划会上玩扑克:
1. 大家各自思考可能要花多久时间完成任务,扣一张牌出来;
2. 师傅喊开牌,大家亮牌,比较大小;
3. 一般最小和最大的两个人PK,说出自己的观点,大家一起讨论;
4. 差异无非来自于两个方面:做什么,怎么做;PO参与讨论回答做什么的问题,师傅和徒弟们讨论解决怎么做的问题;
5. 讨论过后再来几轮,直到大家觉得结果差不多了。
扑克牌估算的匿名性和开放性保证了大家不会人云亦云,也不会因为缺少沟通而难以达成一致。
笔者的经验是一局扑克牌估算大约持续1~5分钟,还是很快的。偶然有黄庄的,一般都是因为PO那里回答不了做成什么样子,某某附加功能是否也要做……等等问题时。
几个问题
1. 为什么分给组而不是个人?
不分个人就打牌使得每个人都不得不思考,因为怕出错了牌又说不出所以然。这样即使日后他不做这个功能,也对这个功能很了解。
2. 为什么不让最后领任务的人自己估算?
因为他很可能因为不知道某代码可用、不知道某软件不行、不懂template(我们因此扔过1个人月代码)……而选择了错误的实现方法。
3. 为什么不让师傅估算大家采纳,他不是最厉害吗?
师傅的想法常常是徒弟们理解不了的——比如为什么不留在女儿国而偏偏去西天取经之类的,呵呵——共同估算就是让大家在思考中对照自己的实现方法和师傅差异的过程。
4. PO怎么还参加?不是不让别人干预吗?
很多问题比如在游戏中“显示武林排行榜”,具体工作量可能不在于怎么做而在于做什么:凭什么排名?排多少名?实时排名还是每周排名?怎么显示排名?……因此PO不能写出一堆文档,然后以不便干预估算为名不参加敏捷计划会议。
PO可以挑战估算,比如:“这真的要这么久吗?我记得上次……”但要有理有据。其实实践中更容易看到的是,团队往往过于激进乐观,PO反而要让他们意识到完整的需求和要求,做出更现实的估算。估算不准确,PO也有责。
5. 一直无法达成一致怎么办?
其实估算不是为了最后那个数字,而是弄清楚做什么和怎么做的问题,如果这两件事情清楚了,但结果却是偏偏有人说4天有人说6天,随便取个数就可以了(事实是应该按墨菲定理取6天)。有师傅在,一般很少会就实现方法争执不下;有PO在,一般很少会就要实现什么争执不下。
不排除有特殊情况比如PO发现自己也没想过排行榜凭什么排行,那么就应该搁置此用户故事;又比如大家觉得如果数据库给力可能实时排名也行但又拿不准,可以暂时搁置到开发的时候再说,但把故事上标注一下“若需要每周自动排名+1天”。如果经常黄庄,Scrum Master要分析总结避免。
6. 四个人出牌不同,师傅先说还是徒弟先说?
想起个脑筋急转弯:科学家 医生 士兵 护士 ……等等一群人在飞机上,飞机结冰快坠落了需要有人(可能不止一个)跳下去,问谁跳?答案是从体重最重的人开始跳,因为可以少跳几个。
因此我们是出牌数字最小的先说,和师徒无关。因为他极有可能掌握最佳实现方法。如果后来发现不是如此,请参考下一条。
7. 都有什么理由可陈述?
按下面的顺序,越靠前的越接近真理,感觉自己接近真理的就一定要举手先说,马后炮招人嫌:
经验事实:我以前做过……咱们有个类库……那个方法我试过不可行……
蛛丝马迹:谁还记得上次……听说隔壁……与上回相比……你以前不是……
逻辑推理:理论上说……我觉得……
几个注意事项
1. 小组内不要有强分工,否则大家会缺省认为肯定是某人的工作。
2. 师傅不要太抢眼,要通过估算鼓励徒弟思考,同时也掌握徒弟的真实水平。
3. 师傅不要太较真,编程规范、易用性、易维护性这些纪律不能放松,但如果徒弟想尝试一种不同但工作量也差不多的方法,可以适当鼓励。
4. Scrum Master监控整个过程,防止太细/争执……等问题。
5. PO必须参加。
----------------------------------------------------------
共同估算依靠PO的参与解决了做什么的问题,依靠师傅的带动解决了怎么做的问题。
共同估算是“跨职能团队”的基础活动之一,之后他们之所以能在每日立会上分享当前进展与困难,就是因为当初是他们一起思考这一任务的,因此对这一任务后来的实际情况非常关心。在发生问题的时候,大家也更可以互相帮助,而不是毫不所知。
下一篇将会涉及日常工作/每日立会等迭代期内的工作。
点击下载免费的敏捷开发教材:《火星人敏捷开发手册》
分享到:
相关推荐
结对编程(Pair Programming)是敏捷开发(Agile Development)中的一种实践方法,它是指两名开发者坐在一起,共享一台电脑,共同编写代码的过程。 结对编程的优点: 1. 提高代码质量:通过结对编程,可以减少编码...
#### 三、自组织团队与松结对编程的应用实践 在实践中,将自组织团队理念与松结对编程方法相结合,可以进一步提升软件开发团队的工作效率和产品质量。 **应用实践案例:** 1. **角色分配与轮换**:团队内部可以...
敏捷开发和极限编程是两种现代软件开发方法论,旨在应对传统开发模式中面临的挑战,特别是对变更的响应能力和快速交付高质量软件的需求。 敏捷开发源于2001年,由一群业界专家提出的敏捷联盟,强调了人与人之间交互...
敏捷软件开发方法中,结对编程是一种实践,它要求两名开发人员在同一台计算机上协同工作。这一方法源自于国际大学生程序设计竞赛(ACM/ICPC)中的团队合作模式。结对编程强调的是两个人的协作,与传统方式相比,它...
极限编程是另一个重要的敏捷框架,包括测试驱动开发(TDD)、结对编程、持续集成等实践,这些方法旨在提高代码质量,减少缺陷,并促进团队协作。 5. **设计模式**: 在敏捷开发中,设计模式是解决常见问题的有效...
《敏捷软件开发原则、模式与实践》一书是由著名软件开发专家、软件工程大师Robert C. Martin所著。这本书自出版以来,就被视为敏捷开发领域内的经典之作,对于软件开发人员、项目经理以及软件项目领导者来说,它提供...
"敏捷开发方法与实践交流.pdf"这本书籍可能更侧重于实际操作和案例研究,分享了敏捷开发在实际项目中的应用经验和教训,帮助读者理解如何在团队中实施敏捷,如何进行敏捷规划、需求管理、迭代开发、每日站会、回顾...
《敏捷软件开发:原则、模式与实践》是Robert C...通过学习,开发者不仅能理解敏捷开发的基本理念,还能掌握具体实践技巧,从而提高团队的开发效率和软件质量。无论是初学者还是经验丰富的专业人士,都能从中受益匪浅。
XP强调编程实践和技术上的卓越,如测试驱动开发(TDD)和结对编程。 3. 用户故事与迭代开发 在敏捷开发中,用户故事是描述用户需求的简短叙述,它帮助团队理解功能的实际价值。每个迭代都会完成一组用户故事,形成...
本书《敏捷软件开发:原则、模式与实践》是由全球知名的软件开发专家和软件工程大师Robert C. Martin所著,该书是关于敏捷开发与极限编程的综合性、实用性指南。书中深入探讨了软件开发人员、项目经理以及软件项目...
**结对编程(Pair Programming)**是极限编程(XP,Extreme Programming)中的一项核心实践,旨在提高软件开发的效率和质量。在这个过程中,两位程序员坐在同一台电脑前,共同编写代码,一人为主程序员(Driver),...
3. **实践技巧**:书中涵盖了测试驱动开发(TDD)、重构、结对编程等敏捷实践,这些技巧有助于确保代码质量,减少缺陷,并促进团队协作。 4. **源码示例**:附带的源码文件,可能是为了便于读者理解和应用书中的...
敏捷开发是一种以人为核心、迭代、循序渐进的软件开发方法论,旨在应对快速变化的需求,提高软件质量和团队效率。以下是对“敏捷开发最佳实践-九大实践”的详细阐述: 1. 完整团队:一个完整的敏捷团队通常包括...
### 交换编程—结对编程的延伸实践 #### 一、引言 交换编程作为一种新型的软件开发模式,是对结对编程的一种延伸和发展。本文旨在深入探讨交换编程的基本概念、实施背景及其在软件开发中的应用价值,并通过实例来...
《敏捷软件开发:原则、模式与实践》是软件开发领域一本经典的著作,它深入探讨了敏捷开发的方法、理念以及在实际工作中的应用。本书对于新手来说,是一本极佳的入门指南,它不仅介绍了敏捷开发的基本概念,还通过...
- **结对编程**:两名开发人员共享同一台电脑,共同编写代码,提高代码质量和团队协作能力。 #### 五、总结 敏捷开发的核心在于通过灵活的开发流程、高效的团队协作以及持续的学习与改进,来应对市场的快速变化和...
《敏捷软件开发:原则、模式与实践》是一本深度探讨敏捷开发理念、方法和技术的经典著作。作者通过本书向读者展示了如何在实际项目中运用敏捷原则,以提高软件开发的效率和质量。书中不仅包含了敏捷开发的基本概念,...
3. **XP(极限编程)**:提倡频繁发布、结对编程、测试驱动开发(TDD)、持续集成等实践,以提高代码质量。 4. **DSDM(动态系统开发方法)**:注重快速交付,强调业务参与和时间盒管理。 ### 四、敏捷实践与工具 ...
"结对编程在Java Web开发课程实践教学中的应用" 结对编程是一种敏捷软件开发方法,它在Java Web开发课程实践教学中有着重要的应用价值。本文将对结对编程在Java Web开发课程实践教学中的应用进行探讨,并对其效果...