博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Two Heads Are Often Better Than One
阅读量:6656 次
发布时间:2019-06-25

本文共 3165 字,大约阅读时间需要 10 分钟。

Two Heads Are Often Better Than One

Adrian Wible

PROGRAMMING REQUIRES DEEP THOUGHT, and deep thought requires soli- tude. So goes the programmer stereotype.

This “lone wolf ” approach to programming has been giving way to a more col- laborative approach, which, I would argue, improves quality, productivity, and job satisfaction for programmers. This approach has developers working more closely with one another and also with nondevelopers—business and systems analysts, quality assurance professionals, and users.
What does this mean for developers? Being the expert technologist is no longer sufficient. You must become effective at working with others.
Collaboration is not about asking and answering questions or sitting in meet- ings. It’s about rolling up your sleeves with someone else to jointly attack work.
I’m a big fan of pair programming. You might call this “extreme collaboration.” As a developer, my skills grow when I pair. If I am weaker than my pairing partner in the domain or technology, I clearly learn from his or her experience. When I am stronger in some aspect, I learn more about what I know and don’t know by having to explain myself. Invariably, we both bring something to the table and learn from each other.
When pairing, we each bring our collective programming experiences— domain as well as technical—to the problem at hand and can bring unique insight and experience into writing software effectively and efficiently. Even in cases of extreme imbalance in domain or technical knowledge, the more experienced participant invariably learns something from the other—perhaps a new keyboard shortcut, or exposure to a new tool or library. For the less- experienced member of the pair, this is a great way to get up to speed.
170 97 Things Every Programmer Should Know
Pair programming is popular with, though not exclusive to, proponents of agile software development. Some who object to pairing ask, “Why should I pay two programmers to do the work of one?” My response is that, indeed, you should not. I argue that pairing increases quality, understanding of the domain and technology, and techniques (like IDE tricks), and mitigates the impact of lottery risk (one of your expert developers wins the lottery and quits the next day).
What is the long-term value of learning a new keyboard shortcut?

How do we measure the overall quality improvement to the product resulting from pairing? How do we measure the impact of your partner not letting you pursue a dead- end approach to solving a difficult problem? One study cites an increase of 40% in effectiveness and speed.* What is the value of mitigating your “lottery risk”? Most of these gains are difficult to measure.

Who should pair with whom?

If you’re new to the team, it’s important to find a team member who is knowledgeable. Just as important, find someone who has good interpersonal and coaching skills. If you don’t have much domain experience, pair with a team member who is an expert in the domain.

If you are not convinced, experiment: collaborate with your colleagues. Pair on an interesting, gnarly problem. See how it feels. Try it a few times.

转载地址:http://ctjto.baihongyu.com/

你可能感兴趣的文章
EJB 教程推荐
查看>>
(五)处理结果管理
查看>>
CDN简介
查看>>
PAT1143 Lowest Common Ancestor(BST)
查看>>
Highcharts——让你的网页上图表画的飞起
查看>>
拼手气红包函数
查看>>
千万级规模高性能、高并发的网络架构经验分享
查看>>
hive 动态分区(Dynamic Partition)异常处理
查看>>
伪随机数算法(一)
查看>>
转:Linux中的内存管理
查看>>
PL/SQL程序设计 第七章 包的创建和应用
查看>>
MySQL8.0-目录结构,配置文件
查看>>
简单水题 POJ 2291 Rotten Ropes
查看>>
小组项目冲刺第五天的个人总结
查看>>
判断是否是一个数组?
查看>>
windows cmd for paramiko
查看>>
多线程
查看>>
折半查找
查看>>
用C++写一个简单的发布者
查看>>
Oracle RAC Failover 详解
查看>>