结对编程的利与弊
结对编程(Pair-Programming)可能是近年来最为流行的编程方式。所谓结对编程,也就是两个人写一个程序,其中,一个人叫Driver,另一个人叫Observer,Driver在编程代码,而Observer在旁边实时查看Driver的代码,并帮助Driver编程。并且,Driver和Observer在一起时可以相互讨论,有效地避免了闭门造车,并可以减少后期的code review时间,以及代码的学习成本。
有实验证明,平均下来,结对编程所花费的时候比单人编程增加了10%,但也会比单人编程减少15%的代码BUG。如果再算上后期代码的维护和学习成本,结对编程比单人编程更有效率,还更为节省成本。无论是对开发团队还是对于Business,结对编程都会是非常不错的Programming Practice。
下面是一些结对编程的优点:
- 程序员互相帮助,互相教对方,可能得到能力上的互补。
- 可以让编程环境有效地贯彻Design。
- 增强代码和产品质量,并有效的减少BUG。
- 降低学习成本。一边编程,一边共享知识和经验,有效地在实践中进行学习。
- 在编程中,相互讨论,可能更快更有效地解决问题。
当然,结队编程也会有一些不好的地方:
- 对于有不同习惯的编程人员,可以在起工作会产生麻烦,甚至矛盾。
- 有时候,程序员们会对一个问题各执己见(代码风格可能会是引发技术人员口水战的地方),争吵不休,反而产生重大内耗。
- 两个人在一起工作可能会出现工作精力不能集中的情况。程序员可能会交谈一些与工作无关的事情,反而分散注意力,导致效率比单人更为低下。
- 结对编程可能让程序员们相互学习得更快。有些时候,学习对方的长处,可能会和程序员们在起滋生不良气氛一样快。比如,合伙应付工作,敷衍项目。
- 面对新手,有经验的老手可能会觉得非常的烦躁。不合适的沟通会导到团队的不和谐。
- 新手在面对有经验的老手时会显得非常的紧张和不安,甚至出现害怕焦虑的的精神状态,从而总是出现低级错误,而老手站在他们后面不停地指责他们导致他们更加紧张,出现恶性循环。最终导致项目进展效率低下,并且团队貌合神离。
- 有经验的人更喜欢单兵作战,找个人来站在他背后看着他可能会让他感到非常的不爽,最终导致编程时受到情绪影响,反而出现反作用。
是否使用结对编程,需要具体问题具体分析,不可盲目。任何事物都有他的好与坏,结对编程也不例外,只有知道了好与坏,你才能更好的利用它。
最后,请记住,人是一种非常复杂的动物,他们的缺点和内心的阴暗面可能会比你想像得还要糟糕,而这些东西是可以让一切事物失败的。所以,正如《人件》所说,人才是软件开发中最核心,也是最需要花时间去关注的事情。
(转载本站文章请注明作者和出处 酷 壳 – CoolShell ,请勿用于任何商业用途)
《结对编程的利与弊》的相关评论
不错哦 偶像啊
求教这个页面的内容是怎么做的,主要是怎么关联文章的点击次数,是使用了什么插件吗?谢谢
今天再看makefile教程的时候,搜索到了这个页面,又看了博主写“如何学好c语言”,写的都非常好,现在脑子里就一个念头:相见恨晚!
为何sort是用日期, 而不是点击呢?
抱歉,怎么跳来这篇
comment 错啦
其实,结对编程为什么提高了效率呢?
因为程序员本来每天有3个小时在编程,5个小时在上网
当后面有个人监督你的时候,你就必须每天8个小时都在编程了。
开个玩笑。
男女搭配…
真没见过这种工作方法,不过我可不喜欢,毕竟有个人在旁边指指点点……
遇之恨晚
推荐一个Blog吧,虽然我不喜欢java ,但是这篇文章还是值得一看
http://blog.zhaojie.me/2011/08/from-the-code-of-no-matter-you-believe-it-or-not.html
老赵点滴 – 追求编程之美
结对编程是不能强迫的,程序员的主动意愿是前提。我们一个团队PP做了很多,大家的反馈很好。
@visquare
打开页面一次,计数器加1不就行了么?有那么难吗??
偶像!
求教 要如何统计点击次数并且显示 是插件还是自己改过程序了? 3Q
恩!整个博客都不错!
hi 你好, 读了你的一些文章,觉得很不错,想知道你这边有好的关于运维的技术blog可以推荐的么?
相见恨晚,以后多来这看看,能学到不少知识!希望国内多一些有深度,有见解的博客!
为什么那篇 iOS5的文章没有了
从来没有试过这种方法。
今天第一次来,受益匪浅啊!
谢谢,最近看了一些酷壳上的文章,很棒~~~
换个题目:结婚的利与弊,比这个还能找到更多的弊端,可是,和谁结婚难道是不需要选择的么?结对编程也不是随便指两个人就说:从今天起你们一块儿工作了!有功夫在这里瞎指责,不如考虑下怎么恰当地使用这些方法,或者提出一个更好的来。
1
请记住,人是一种非常复杂的动物,他们的缺点和内心的阴暗面可能会比你想像得还要糟糕,而这些东西是可以让一切事物失败的。
知道最近才看了博主的网站,受益匪浅啊,真心感谢博主对我们这批后来者无私的帮助~~
真棒!!!!!!!!
@visquare
设定几个变量,比如阅读量、发表时间、评分,然后就O了
后辈前来拜读
博主很厉害,向你学习。
近期学敏捷,恰好结对也是要求的,但还未实践过。
利弊确实参半,但要知道每个程序员一天的有效代码也就十几行~
大部分由于质量差、重构而废弃。
所以质量还是最关键的~
博主确实非常善于总结,我辈楷模!
别人推荐的!来看看
结对编程要因团队,因项目来定,博主总结得非常不错,学习了……
不错啊。在微博进来的。
@deepsky
文章写的很好
体会过结对编程的好处的情况下会觉得还是代价是值得的。也有一些前提,比如水平要不能相差太远,不适合新手,要比较合的来。大公司一般可以做到这几点,在招聘的时候就基本保证了,所以用起来利大于弊。一家之言
博客 很有深度,专家博客。很多内容没有耐心读下去额。o(︶︿︶)o 唉
我的博客 http://FansUnion.cn,欢迎来踩~
我的博客 http://FansUnion.cn 欢迎来踩~
最近怎么没有文章更新了啊~
还没见过现实中使用这种编程的,我们组是2个人写完code,然后互相review
haha““不错哦,能学到很多东西
酷哥怎么删掉最近的几篇文章了?
编译器优化的时候(有些时候)为什么会打乱一些指令的执行顺序?这是基于怎样的原理与考虑?
额!
指令重排序的原因:对主存的一次访问一般花费硬件的数百次时钟周期。处理器通过缓存(寄存器、cpu缓存等)能够从数量级上降低内存延迟的成本这些缓存为了性能重新排列待定内存操作的顺序。也就是说,程序的读写操作不一定会按照它要求处理器的顺序执行。
貌似我的文章被删除了@程序员主页
哎!