BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

结对编程的经济价值论

| 作者 Mike Bria 关注 0 他的粉丝 ,译者 金毅 关注 0 他的粉丝 发布于 2009年6月26日. 估计阅读时间: 3 分钟 | GMTC大前端的下一站,PWA、Web框架、Node等最新最热的大前端话题邀你一起共同探讨。

亲爱的读者:我们最近添加了一些个人消息定制功能,您只需选择感兴趣的技术主题,即可获取重要资讯的邮件和网页通知

“究竟为什么我们要使用两个人来同时做同一件事情呢?”这往往是初次听说结对编程的人的第一反应。实际上,他们觉得结对编程使写代码的成本翻了一倍。Dave Nicollete用数字说话,告诉大家结对编程是如何省钱,而不是浪费钱的。

由于错误地认为编程主要就是打字,结对编程的经济价值论也就经常被误解。事实上,当然,大部分的编程其实就是在思考,结果往往会做出很多糟糕的决定,或者犯下很多的错误——这些错误最终还得由开发人员(以及他们的公司)买单。

这就是结对编程价值论建立的基础,也是它为什么难以量化的原因。 Dave Nicolette在他最近的一篇文章中是这么概述的:
结对的价值主要体现在手把手纠正,从而把错误扼杀在萌芽中。手把手纠正涉及面小,而且能跟结对编程的工作流程无缝结合起来,通常 甚至都感觉不到,很自然...带来的价值就是能够很方便地进行检查,从而防止在未来某个时间不得不返工的情况出现...要想观测或者量化实施后的效果并不 简单,因为坏的结果从来没有发生过,你也就没法比较了。
所以,结对的价值体现在节约了未来的时间,“时间就是金钱”。但是值多少钱呢?还是在这篇文章中,Dave试着向大家阐述了几个观点来回答这个问题。
在最近的一次结对中,Dave一直记录着结对伙伴指出搭档错误以及关于设计方面的讨论的时间。然后,他们给出这些事情为将来省下了多少时间,再利用这些信息继续做进一步的计算:
在Alistair Corkburn的早期著作中,他曾经计算过一个IT工作者的成本要每分钟2.1美元...在我们的结对过程中,我们进行了2次简短的关于设计的讨论,随 之做出了小的重构。根据我们的计算,这次重构为未来的维护工作节省出了4小时。这就意味着大约2.1 x 120 = 252.00美元。如果我们共发现了12个小错误,平均每个错误节约了30秒的调试时间,那么这就值.5 x 2.1 x 12 = 12.60美元。总共的话,我们为公司每90分钟省下了276.60美元,或者说一小时省下大概180.00美元。
...
某公司有个小 规模的IT部门,总共40个开发人员,分散在几个XP团队。我们假设开发人员每天结对5个小时,那么一共每周结对时间为20对 x 5小时 x 一周5天 = 500小时。假设每个结对每小时节省180美金,那么平均每周节约90000美元。如果全年都把节约率控制在这个水平线上下,那么团队一年工作50周(这 是美国,假期不长),公司就会因为开发团队的结对编程,一年节省450万美元。
450万美金呢,对一个只有40个开发人员的公司呀。但Dave也不得不承认,这只是从一次结对编程中获取的初步计算,所以并没有科学性,但这仍然可以引发大家的思考。

你怎么看呢?

查看英文原文:A Dollar Value On Pair Programming

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

楼主你 by Huang Hideto

扯的我蛋疼

结对编程想法不错 by Li Qiang

结对编程是一种理想化的想法,它只适合两个人水平相当、知识结构存在互补的情况。设想一下,假如是师徒结对编程,师傅肯定会受制于徒弟的各种低级错误中,影响师傅的工作进度。又或者是两个水平差异较大的程序员结对,同样有这样的麻烦。
还有一个最重要的问题,在于结对编程要求开放性。很多程序员在长期工作中形成的经验与教训,并不愿意与其它人共享。试想,如果在技术上有保留,还怎么结对?怎么结好对?

Re: 结对编程想法不错 by 张 晓庆

引用作者的一个回复:
Fred,

Have you ever tried pair programming yourself?

I myself made similar arguments of logic years ago prior to actually ever really understanding (well, experiencing) pairing.

The reality is that when a team adopts pair programming and applies it with respect and a shared understanding of purpose and etiquette, in most healthy environments, literally none the suspicions you mention turn out to be true at all.

As Dave implies, the value is not easy to justify quantitatively or logically (although I still do make an attempt here), you just need to see it work for yourself to really understand.

Cheers
MB

Re: 结对编程想法不错 by im Kevin

说得很对,结对编程并不是没有条件的。中国的很多程序员非常高傲,喜欢显摆,你让另外一个人坐在他旁边,纠正他的代码设计过程,他就算嘴上不说,心理肯定也一百个不爽,结对编程的意义就无法体现出来了。

Re: 结对编程想法不错 by 熊 小

结对的确需要条件,但是如果我们都停留在口头上觉得不行,不去实际尝试,恐怕说不出来哪些是必要的前提吧?就我所知的范围内,只要是尝试过结对的开发人员,没有不喜欢的。。

一个程序员的联想 by yan lix

2.1 * 60 * 8 * 22 * 12 = 266112 ?

i'm just wondering

Re: 结对编程想法不错 by G. Conan

哈哈,有同感!

量化? by 陈 鹏

这莫精细的量化是有点扯

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

8 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT