首页 > 流程方法 > 结对编程的利与弊

结对编程的利与弊

2009年3月2日 发表评论 阅读评论 5,113 人阅读    

cccpairprogramming结对编程(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. 有经验的人更喜欢单兵作战,找个人来站在他背后看着他可能会让他感到非常的不爽,最终导致编程时受到情绪影响,反而出现反作用。

是否使用结对编程,需要具体问题具体分析,不可盲目。任何事物都有他的好与坏,结对编程也不例外,只有知道了好与坏,你才能更好的利用它。

最后,请记住,人是一种非常复杂的动物,他们的缺点和内心的阴暗面可能会比你想像得还要糟糕,而这些东西是可以让一切事物失败的。所以,正如《人件》所说,人才是软件开发中最核心,也是最需要花时间去关注的事情。

好烂啊有点差凑合看看还不错很精彩 (15 人打了分,平均分: 4.80 )
Loading ... Loading ...
  1. dghuis9
    2011年5月19日17:49 | #1

    不错哦 偶像啊

  2. visquare
    2011年5月21日23:34 | #2

    求教这个页面的内容是怎么做的,主要是怎么关联文章的点击次数,是使用了什么插件吗?谢谢

  3. deepsky
    2011年6月14日22:02 | #3

    今天再看makefile教程的时候,搜索到了这个页面,又看了博主写“如何学好c语言”,写的都非常好,现在脑子里就一个念头:相见恨晚!

  4. cs
    2011年6月16日19:57 | #4

    为何sort是用日期, 而不是点击呢?

  5. cs
    2011年6月16日20:00 | #5

    抱歉,怎么跳来这篇
    comment 错啦

  6. tossking
    2011年6月17日10:22 | #6

    其实,结对编程为什么提高了效率呢?
    因为程序员本来每天有3个小时在编程,5个小时在上网
    当后面有个人监督你的时候,你就必须每天8个小时都在编程了。
    开个玩笑。

  7. phierus
    2011年6月27日15:58 | #7

    男女搭配…

  8. 2011年7月21日17:53 | #8

    真没见过这种工作方法,不过我可不喜欢,毕竟有个人在旁边指指点点……

  9. bluecipher_cms
    2011年8月5日12:58 | #9

    遇之恨晚

  10. kaitian
    2011年8月10日12:54 | #10

    推荐一个Blog吧,虽然我不喜欢java ,但是这篇文章还是值得一看
    http://blog.zhaojie.me/2011/08/from-the-code-of-no-matter-you-believe-it-or-not.html

    老赵点滴 – 追求编程之美

  11. Shaopeng
    2011年8月17日17:08 | #11

    结对编程是不能强迫的,程序员的主动意愿是前提。我们一个团队PP做了很多,大家的反馈很好。

  12. ever
    2011年8月25日14:55 | #12

    @visquare
    打开页面一次,计数器加1不就行了么?有那么难吗??

  13. 无心X柳
    2011年8月26日11:03 | #13

    偶像!

  14. 卖葱的少年
    2011年10月30日18:28 | #14

    求教 要如何统计点击次数并且显示 是插件还是自己改过程序了? 3Q

  15. 神锋星际
    2011年10月31日17:38 | #15

    恩!整个博客都不错!

  16. bingying
    2011年11月8日00:49 | #16

    hi 你好, 读了你的一些文章,觉得很不错,想知道你这边有好的关于运维的技术blog可以推荐的么?

  17. blueheart
    2011年11月16日11:02 | #17

    相见恨晚,以后多来这看看,能学到不少知识!希望国内多一些有深度,有见解的博客!

  18. Dmray
    2011年11月18日22:52 | #18

    为什么那篇 iOS5的文章没有了

  19. etrling
    2011年11月24日19:09 | #19

    从来没有试过这种方法。

  20. darren
    2011年12月26日20:46 | #20

    今天第一次来,受益匪浅啊!

  21. CG
    2012年2月19日11:02 | #21

    谢谢,最近看了一些酷壳上的文章,很棒~~~

  22. jackhuang
    2012年3月16日21:41 | #22

    换个题目:结婚的利与弊,比这个还能找到更多的弊端,可是,和谁结婚难道是不需要选择的么?结对编程也不是随便指两个人就说:从今天起你们一块儿工作了!有功夫在这里瞎指责,不如考虑下怎么恰当地使用这些方法,或者提出一个更好的来。

  23. 2012年5月15日16:46 | #23

    1

  1. 2011年2月12日10:21 | #1
  2. 2011年2月13日04:16 | #2
  3. 2011年2月24日12:04 | #3

无觅相关文章插件,快速提升流量