为什么程序员都害怕结对编程?

举报
敏捷开发 发表于 2024/05/27 14:15:31 2024/05/27
【摘要】 结对编程是对一个人的心智、道德修养更高的要求。

结对编程是极限编程(XP)中的工程实践之一。但大家对结对编程的态度,褒贬不一,有人很喜欢,觉得它有利于团队的知识共享,打破成员间的知识孤岛,还利于促进团队的协作,提高效率等等好处;而有的人则很讨厌,觉得结对编程会降低效率,是在增加成本,尤其是两个开发人员经验差距较大时,而且这种发生会让开发这无法集中注意力,每个人的工作方式都不同,在同一台电脑上工作,挑战性很大。

一、为什么要结对编程?

我们需要明白的一点是,结对编程是一把双刃剑,有优势也有劣势。虽然它不能解决所有问题,但对比其他方法,它也是降低工作难度的一个行之有效的方法。

对于管理者来说要明白,结对编程虽然在项目开始时会增加成本,但结对编程可以减少很多Bug的产生,显著降低后续的成本。另外通常情况下,人会倾向关注整体而非具体细节。结对编程就是为了能更好地兼顾二者,通过结对让程序员及时发现编程中的错误。

编程时由两名程序员分别扮演“驾驶员”(负责编写代码)和“导航员”(负责审查代码)。

世界上没有两片完全相同的树叶”,同样没有任何两个程序员会以完全相同的方式看待代码,特别是面对一些复杂的代码时,关注的点或者角度的不同,及时发现问题的能力也会大大提高,也可以尽可能地减少Bug的产生。

二、让结对编程更易成功的技巧

下面就分享5个结对编程的技巧以及一些注意事项,帮助大家更好地实现结对编程。

1.开发相同的代码

使用结对编程的最佳方式就是并排坐在显示器前,开发人员使用两个键盘,两个鼠标,共用一个屏幕和一台电脑。开发者控制并编写代码,扮演驾驶员的角色,另一位担任导航员的角色,专注于确保代码是正确的,并考虑改进应用程序的设计,遵循最佳实践。

为了确保大家饱满的动力,可以以半小时的节奏,角色互相交换进行。让两位程序员都保持动力和细心。除了角色可以互换,结对的伙伴也可以变化。

2.根据任务进行编程分组

不同的程序员之间实力和经验都是不同的。如果是以分享知识和技能转化为主,那么初级和高级程序员可以组在一起,以获得最佳的学习体验。但如果要求代码质量,避免错误或者开发困难的任务,那么建议两位经验丰富的程序员一起,这样能保证任务的高效率和低错误率。

3.组织团队会议,互相交流鼓励

每天约三到五分钟的短会,让所有的同事聚集在一起讨论当前项目的细节,交流想法,这样可以更好地激励团队。此外,每个成员都有机会进行个人接触,这样也能积极促进团队氛围的形成和合作。

4.和产品经理保持密切沟通

在项目初期,软件的需求并不会非常明确清晰且确定,所以和产品经理保持密切的沟通联系,可以让程序员保持对需求有最新和准确的理解,便于后续开发。通过和产品经理的沟通,也能不断给出反馈意见,从而让项目更好地实施和推进。

5.不断测试

开发人员首先模拟测试错误的代码,然后再开发一个足以通过测试的代码。最后,修改代码以符合标准。

总之,结对编程是对一个人的心智、道德修养更高的要求。编码不再是私人的工作,而是一种公开的“表演”,程序员的代码、工作方式、技术水平都变得公开和透明。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。