结对编程是极限编程(XP)中的工程实践之一。但大家对结对编程的态度,褒贬不一,有人很喜欢,觉得它有利于团队的知识共享,打破成员间的知识孤岛,还利于促进团队的协作,提高效率等等好处;而有的人则很讨厌,觉得结对编程会降低效率,是在增加成本,尤其是两个开发人员经验差距较大时,而且这种发生会让开发者无法集中注意力,每个人的工作方式都不同,在同一台电脑上工作,挑战性很大。
一、为什么要结对编程?
我们需要明白的一点是,结对编程是一把双刃剑,有优势也有劣势。虽然它不能解决所有问题,但对比其他方法,它也是降低工作难度的一个行之有效的方法。
对于管理者来说要明白,结对编程虽然在项目开始时会增加成本,但结对编程可以减少很多Bug的产生,显著降低后续的成本。 另外通常情况下,人会倾向关注整体而非具体细节。结对编程就是为了能更好地兼顾二者,通过结对让程序员及时发现编程中的错误。
编程时由两名程序员分别扮演“驾驶员”(负责编写代码)和“导航员”(负责审查代码)。
“世界上没有两片完全相同的树叶”,同样没有任何两个程序员会以完全相同的方式看待代码,特别是面对一些复杂的代码时,关注的点或者角度的不同,及时发现问题的能力也会大大提高,也可以尽可能地减少Bug的产生。
二、让结对编程更易成功的技巧
下面就分享5个结对编程的技巧以及一些注意事项,帮助大家更好地实现结对编程。
1.开发相同的代码
使用结对编程的最佳方式就是并排坐在显示器前,开发人员使用两个键盘,两个鼠标,共用一个屏幕和一台电脑。开发者控制并编写代码,扮演驾驶员的角色,另一位担任导航员的角色,专注于确保代码是正确的,并考虑改进应用程序的设计,遵循最佳实践。
为了确保大家饱满的动力,可以以半小时的节奏,角色互相交换进行。让两位程序员都保持动力和细心。除了角色可以互换,结对的伙伴也可以变化。
2.根据任务进行编程分组
不同的程序员之间实力和经验都是不同的。如果是以分享知识和技能转化为主,那么初级和高级程序员可以组在一起,以获得最佳的学习体验。但如果要求代码质量,避免错误或者开发困难的任务,那么建议两位经验丰富的程序员一起,这样能保证任务的高效率和低错误率。
3.组织团队会议,互相交流鼓励
每天约三到五分钟的短会,让所有的同事聚集在一起讨论当前项目的细节,交流想法,这样可以更好地激励团队。此外,每个成员都有机会进行个人接触,这样也能积极促进团队氛围的形成和合作。
4.和产品经理保持密切沟通
在项目初期,软件的需求并不会非常明确清晰且确定,所以和产品经理保持密切的沟通联系,可以让程序员保持对需求有最新和准确的理解,便于后续开发。通过和产品经理的沟通,也能不断给出反馈意见,从而让项目更好地实施和推进。
5.不断测试
开发人员首先模拟测试错误的代码,然后再开发一个足以通过测试的代码。最后,修改代码以符合标准。
总之,结对编程是对一个人的心智、道德修养更高的要求。 编码不再是私人的工作,而是一种公开的“表演”,程序员的代码、工作方式、技术水平都变得公开和透明。