写点什么

结对编程如何才能真正起作用

  • 2010-01-24
  • 本文字数:1972 字

    阅读完需:约 6 分钟

皇家信号学校的 Stuart Wray 为 IEEE 软件杂志 2010 年的一月刊撰写了一篇文章,题目是“结对编程如何才能真正起作用”。

在文章中,它举出可各种结对的方法(帮工- 学徒/ 驱动者- 导航者),并指出了工作的一般方式:

> 作为使用结对编程的开发者,我自己的的经验是这样的,它并非只是一种一个人编码,另一个人观察的技术。两个程序员会很紧密地在一起工作,总是在交谈,快速记下对要做的事儿的提醒,并且在屏幕上指出代码的片段。(结对编程的特征之一就是,如果你正确地使用了这种方法,那么在一天结束的时候,屏幕上会满是油腻的手指印。)程序员轮番使用键盘,经常会用这样的话来进行交换,“不,让我向你展示一下我是什么意思。”

以他对有效的结对编程的描述为基础(并且指出并非所有对结对编程的实现都是有效的),他提出了能够使有效的结对编程变得成功的四种机制。

机制一:结对编程者的交谈

> Brian Kernighan 和 Rob Pike 建议要大声地解释问题,即便是向毛绒玩具也要那样,John 正在研究的一种实践叫做“橡胶植物效应(rubber-plant effect)”。结对编程的一部分效力是由于持续触发这种效应而得到的:当一位程序员被卡住了,那么反复的交谈会使其突破,这种方式与单独工作的程序员大声地说出自己的问题是类似的。

他还讨论了交谈带来的更大的好处,其中应用了他所谓的“专家程序员理论”——随着需要知识的问题被更有效地解决,结对的两个人会彼此更了解对方。

> 那么这可能正是专家程序员理论起作用的地方:专家更可能会提出有深度的问题,那会对被卡住的程序员起到很大的提示作用。看起来还可能仅仅是认为你正在与一位专家交谈——或者假装——那会帮助被卡住的程序员得出那种有深度的问题,可能在之前专家曾经问过他们。

将交谈的价值累加起来,他指出:

> 这样,第一种机制让我们可以猜测,对程序谈论更多的程序员会更有生产力,而不时地互相提出有深度的问题的人会是生产力最高的。

机制二:结对编程者会注意到更多细节

“你看不到自己的错误”,这是软件开发中的(也是很多其它学科的)公理。

Wray 将这与改变视盲和无意视盲理论相关联。

> 我们所能注意到的东西取决于我们期望看到什么,以及我们无意识地认为突出的东西。所以,尽管成功的结对编程者通常更多地会关注同样的东西,但是他们也可能会注意到不同的东西。
>
> 因此,一起编程的两个人不会擅长同样的知识或者类别:一个人可能会更快地指出某个方面的问题,而另一个人对于其他方面更快一些。这样他们的工作效率就取决于他们通过观察来找到问题的速度。两个人的头脑肯定会比一个人的好。事实上,当人们开始进行结对编程的时候,最早做出的发现之一就是,不输入代码的人总是会更快地找出拼写错误:“哦,在这里你漏掉了逗号。”

接下来,他提出了关于结对疲劳现象的警告:当两个程序员进行结对,他们发现和无法发现的东西会变得越来越类似。最终,两双眼睛的优势会丧失殆尽。

> 结对疲劳使得我们经常对结对进行轮换:
>
> 有些结对编程者认为轮换是实践中可选的部分,而且在小型团队或者是没有几个程序员愿意结对的团队中,可能没有其它的选择。但是,结对疲劳意味着最终他们的生产力会降低。

机制三:与不好的实践作斗争

由于来自同侪的压力而不使用不好的实践,有人已经明确地指出这是有效的结对编程的优势。

他讨论了“编码并修正”编程的例子,并将它与老虎机赌博成瘾相关联。

> 这是交互编程特定的属性,使得我们很难做正确的事情。使用编码并修正的方式,我们会随意的修改程序,每次运行代码的时候,就像将硬币放在老虎机里面一样。老虎机是我们所知道的最容易上瘾的一种赌博形式。而来自于“编码并修正”编程会带来类似的不可预测的好处,这意味着它同样让人容易上瘾。
>
> 而结对编程比较不容易受到不好的实践的影响,因为程序员们会承诺以特定的方式编写代码,并确保两个人都信守承诺。在人们容易犯错的工作中,两人结对工作的方式变得越来越流行,这会让我们认真考虑,结对的压力也可能是我们的一种解决方案。

机制四:分享并评价专家的意见

个人的生产力之间会有巨大的不同,至少可以将其分解成十个因素来度量。这通常意味着对难度和时间的估计是不准确的。对于好的和坏的程序员都是这样——你只能通过与其紧密地工作来确定一个人的编程能力。

> 大多数程序员会解决他们自己的问题,因此没有人知道他们有多棒(或者有多糟糕)。但在结对编程中,人们持续地一起工作。因为他们会不停地交换搭档,团队中的每个人都知道对于特定的领域谁是最专业的。出于这种比较,他们也会意识到自己的专业等级。这样我们应该期望,比起单独的编程团队,通过结对编程可以对时间和难度进行更准确的估计。从我们的经验看,这的确是那样的。

- - - - - -

在你的环境中哪些技术和机制使得结对编程更加有效呢?

InfoQ 中有更多结对编程的内容,就在这里

查看英文原文: How Pair Programming Really Works

2010-01-24 23:082537
用户头像

发布了 340 篇内容, 共 129.5 次阅读, 收获喜欢 13 次。

关注

评论

发布
暂无评论
发现更多内容

华为视频独家呈现:发布会开场舞《见非凡》AiMax 版来袭

最新动态

Python将表格文件中某些列的数据整体向上移动一行

不在线第一只蜗牛

Python 机器学习 Excel

低代码开发技术在农村现代化中的应用探索

EquatorCoco

低代码 数智化

李飞飞团队 ReKep:空间智能机器人可整合 GPT-4o;苹果首款 AI 手机 iPhone 16 发布丨RTE 开发者日报

声网

如何留住自己的团队?

秃头小帅oi

爱回收商品详情数据接口

tbapi

爱回收API 爱回收商品详情数据接口

如何看待:低代码开发平台的兴起无需经验?

快乐非自愿限量之名

低代码

读书笔记:简单高效的工作方式

老张

读书笔记 团队管理 远程办公

代币化资产如何拯救 DeFi:让金融重回价值创造的正轨

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 NFT开发 代币开发

什么是 structuredClone?如何实现深拷贝?

伤感汤姆布利柏

洞悉市场脉搏,从实时监控商品信息开始 —— 淘宝API的力量

技术冰糖葫芦

API Explorer平台 api 网关 API Gateway API 测试 pinduoduo API

关于粒子滤波的解析

梦笔生花

粒子滤波

深入理解Argo CD工作原理

快乐非自愿限量之名

k8s

再创辉煌!望繁信科技斩获第十三届中国创新创业大赛四川赛区桂冠

望繁信科技

数字化转型 流程挖掘 流程资产 流程智能 望繁信科技

现在的 AI ,有多会做老师?

豆包MarsCode

Python 人工智能 程序员 AI 求职

新闻“样板间”提升50%开发效率,20家新闻媒体应用批量鸿蒙化

最新动态

mac苹果电脑矢量绘图软件:Sketch for mac 中文激活版

你的猪会飞吗

sketch Mac Mac软件下载站 mac破解软件下载

低代码平台与云服务技术研究白皮书

不在线第一只蜗牛

低代码 云服务

互联网大厂Java面试高手心法,在寒潮之下找到自己心仪的 offer。

码哥字节

Java 后端面试

议程抢先看!安谋科技、英特尔、浪潮信息、蚂蚁集团等企业大咖齐聚 2024 云栖大会操作系统开源专场

OpenAnolis小助手

操作系统 云栖大会 龙蜥社区 龙蜥操作系统 AIibaba CIoud Linux

DApp开发入门指南:从概念到实践

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 NFT开发 代币开发

Docker 容器中镜像导出/导入

快乐非自愿限量之名

Docker 容器

对游戏语音软件Oopz遭遇DDoS攻击后的一些建议

网络安全服务

负载均衡 udp 语音聊天软件 DDoS 攻击 黑神话悟空

增强洞察力,通过预测性规划引领企业走向光明未来

智达方通

全面预算管理 财务规划和分析 财务管理 财务转型

软件测试学习笔记丨Vim编辑器的常用命令

测试人

软件测试

电商数据分析师必备:京东商品详情API返回值解读

技术冰糖葫芦

api 网关 API Gateway API 测试 pinduoduo API

DBeaver 24.2 发布下载,新增功能概览

sysin

数据库 sql 管理工具 Dbeaver

参赛心得和思路分享:2021第二届云原生编程挑战赛2: 实现一个柔性集群调度机制

阿里云天池

云原生

第67期 | GPTSecurity周报

云起无垠

AI加持的云端IDE——三种方法高效开发前后端聊天交互功能

豆包MarsCode

人工智能 ide 程序员 AI 编程语言

财务团队应如何推动企业创新升级和可持续发展

智达方通

团队协作 企业管理 战略规划 全面预算管理

结对编程如何才能真正起作用_研发效能_Shane Hastie_InfoQ精选文章