1、PairProgramming
-
结对编程(Pair-Programming)可能是近年来最为流行的编程方式。所谓结对编程,也就是两个人写一个程序,其中,一个人叫 Driver,另一个人叫 Observer,Driver 在编程代码,而 Observer 在旁边实时查看 Driver 的代码,并帮助 Driver 编程。并且,Driver 和 Observer 在一起时可以相互讨论,有效地避免了闭门造车,并可以减少后期的 code review 时间,以及代码的学习成本。
-
有实验证明,平均下来,结对编程所花费的时候比单人编程增加了 10%,但也会比单人编程减少 15% 的代码 BUG。如果再算上后期代码的维护和学习成本,结对编程比单人编程更有效率,还更为节省成本。无论是对开发团队还是对于 Business,结对编程都会是非常不错的 Programming Practice。
-
下面是一些结对编程的优点:
- 1、程序员互相帮助,互相教对方,可能得到能力上的互补。
- 2、可以让编程环境有效地贯彻 Design。
- 3、增强代码和产品质量,并有效的减少 BUG。
- 4、降低学习成本。一边编程,一边共享知识和经验,有效地在实践中进行学习。
- 5、在编程中,相互讨论,可能更快更有效地解决问题。
-
当然,结队编程也会有一些不好的地方:
- 1、对于有不同习惯的编程人员,可以在起工作会产生麻烦,甚至矛盾。
- 2、有时候,程序员们会对一个问题各执己见(代码风格可能会是引发技术人员口水战的地方),争吵不休,反而产生重大内耗。
- 3、两个人在一起工作可能会出现工作精力不能集中的情况。程序员可能会交谈一些与工作无关的事情,反而分散注意力,导致效率比单人更为低下。
- 4、结对编程可能让程序员们相互学习得更快。有些时候,学习对方的长处,可能会和程序员们在起滋生不良气氛一样快。比如,合伙应付工作,敷衍项目。
- 5、面对新手,有经验的老手可能会觉得非常的烦躁。不合适的沟通会导到团队的不和谐。
- 6、新手在面对有经验的老手时会显得非常的紧张和不安,甚至出现害怕焦虑的的精神状态,从而总是出现低级错误,而老手站在他们后面不停地指责他们导致他们更加紧张,出现恶性循环。最终导致项目进展效率低下,并且团队貌合神离。
- 7、有经验的人更喜欢单兵作战,找个人来站在他背后看着他可能会让他感到非常的不爽,最终导致编程时受到情绪影响,反而出现反作用。
-
是否使用结对编程,需要具体问题具体分析,不可盲目。任何事物都有他的好与坏,结对编程也不例外,只有知道了好与坏,你才能更好的利用它。
-
最后,请记住,人是一种非常复杂的动物,他们的缺点和内心的阴暗面可能会比你想像得还要糟糕,而这些东西是可以让一切事物失败的。所以,正如《人件》所说,人才是软件开发中最核心,也是最需要花时间去关注的事情。