【敏捷开发】结对编程
结对编程简介
- 所谓结对编程,也就是两个人写一个程序,其中,一个人叫Driver,另一个人叫Observer,Driver在编程代码,而Observer在旁边实时查看Driver的代码,并帮助Driver编程。
- 并且,Driver和Observer在一起时可以相互讨论,有效地避免了闭门造车,并可以减少后期的code review时间,以及代码的学习成本。
- 有实验证明,平均下来,结对编程时间花销比单人编程增加10%的时间,但也会比单人编程减少15%的代码BUG。
- 如果再算上后期代码的维护和学习成本,结对编程比单人编程更有效率,还更为节省成本。
所以无论是对开发团队还是对于Business,结对编程都会是非常不错的Programming Practice。
- 实施结对编程技术将给软件项目的开发工作带来好处,只是这些好处必须经过缜密的思考和计划才能真正体现出来。
- 而另一方面,两个有经验的人可能会发现配对编程里没有什么技能的转移,但是让他们在不同的抽象层次解决同一个问题会让他们更快地找到解决方案,而且错误更少。
- 两个程序员具有相同的缺点和盲点的可能性很小,所以我们当我们采用结对编程的时候会获得一个强大的解决方案。而这个解决方案恰恰是其它软件工程方法学中所没有的。
结对编程的优点
- 程序员互相帮助,互相教对方,可以得到能力上的互补。
- 可以让编程环境有效地贯彻Design。
- 增强代码和产品质量,并有效的减少BUG。
- 降低学习成本。一边编程,一边共享知识和经验,有效地在实践中进行学习。
- 在编程中,相互讨论,可能更快更有效地解决问题。
结队编程缺点
- 对于有不同习惯的编程人员,可以在起工作会产生麻烦,甚至矛盾。
- 有时候,程序员们会对一个问题各执己见(代码风格可能会是引发技术人员口水战的地方),争吵不休,反而产生重大内耗。
- 两个人在一起工作可能会出现工作精力不能集中的情况。程序员可能会交谈一些与工作无关的事情,反而分散注意力,导致效率比单人更为低下。
- 结对编程可能让程序员们相互学习得更快。有些时候,学习对方的长外,可能会和程序员们在起滋生不良气氛一样快。比如,合伙应付工作,敷衍项目。
- 面对新手,有经验的老手可能会觉得非常的烦躁。不合适的沟通会导到团队的不和谐。
- 新手在面对有经验的老手时会显得非常的紧张和不安,甚至出现害怕焦虑的的精神状态,从而总是出现低级错误,而老手站在他们后面不停地指责他们导致他们更加紧张,出现恶性循环。最终导致项目进展效率低下,并且团队貌合神离。
- 有经验的人更喜欢单兵作战,找个人来站在他背后看着他可能会让他感到非常的不爽,最终导致编程时受到情绪影响,反而出现反作用。
结对编程的七种激励效应
- 互相督促,互相协商,互相鼓励,互相纠错,互相学习,互相信任。
技巧与窍门
- 驾驶员应该留点时间去发现和纠正他自己的错误。
- 可以休息,但不能偷懒。
- 开始编程之前最好能够自己的工作习惯和对方说清楚。
- 采用边准编码。
- 做积极主动的听众,先听懂,再复述,再总结。
- 多说多交谈。
- 不明白就问。
- 尊重你的搭档,也让他尊重你。
搭档的组合方式
- 高手-高手:以最快的速度冲刺,完成最复杂最困难的任务。
- 专家-中等程序员:完成中等难度的任务,并提高其中一位程序员的水平。
- 专家-新手:完成最简单的任务,同时对程序员进行培训。
- 新手-新手:把项目中相对不那么复杂部分的产品代码写出来,并让两位程序员积累经验。
- 外向-外向:两人经过长时间深思熟虑的富有创造形的讨论,一个优秀的创造形解决方案诞生了。
- 外向-内向:利用搭档俩各自的长处去完成工作,在这一过程中帮助两人发现和客服自身弱点。
- 内向-内向:沉默是一种压力,它往往会导致出色的解决方案。
优秀结对程序远的7个好习惯
- 注意休息,适当放松,至少一个小时休息一次。
- 谦虚谨慎,戒骄戒躁。
- 既要自信,又要谦虚。
- 交流。
- 倾听。
- 积极思考,积极参与。
- 不卑不亢,以礼服人。
小结
是否使用结对编程,需要具体问题具体分析,不可盲目。任何事手都有他的好与坏,结对编程也不例外,只有知道了好与坏,你才能更好的利用它。
最后,需要我们记住的是,人是一种非常复杂的动物,他们的缺点和内心的阴暗面可能会比你想像得还要糟糕,而这些东西是可以让一切事物失败的。所以,正如《人件》所说,人才是软件开发中最核心,也是最需要花时间去关注的事情。