只有完美代码不够的,如何做一个完美的Pull Request?

栏目: IT技术 · 发布时间: 4年前

内容简介:想要提高团队绩效,找到瓶颈是第一步。现实中,最大的限制因素不是编码速度,而是代码审查。因此,为了加快审查速度,笔者对比了两种pull request:我的结论是,有九种方式能让审查pullrequest更轻松。在写一个新功能的时候,会有很多与之相关的信息。写代码时要全盘考虑需求,第三方系统的局限性,以及和遗留代码库的交互。但是别人不了解其上下文来源,所以看到这个代码时会问“它为什么在这?”或是“为什么要选择这种方法?”

想要提高团队绩效,找到瓶颈是第一步。现实中,最大的限制因素不是编码速度,而是代码审查。因此,为了加快审查速度,笔者对比了两种pull request:

  • 注释很少并且快速合并的pullrequest
  • 有很多注释,需要多轮审查的pull request

我的结论是,有九种方式能让审查pullrequest更轻松。

1.添加关于“为什么”的代码注释

在写一个新功能的时候,会有很多与之相关的信息。写代码时要全盘考虑需求,第三方系统的局限性,以及和遗留代码库的交互。但是别人不了解其上下文来源,所以看到这个代码时会问“它为什么在这?”或是“为什么要选择这种方法?”

因此要通过添加解释性的注释,让阅读代码的人提前知晓“为什么”。笔者不认同一些人宣扬的观点:注释有害,应当忽略。

注释有很多种类。那些描述代码用途的确实是累赘。提取一个方法,采用一个精心挑选的命名,就能消除这种麻烦。另一方面,当解释为什么这样写代码时,也增加了代码阅读者的信息量。这些注释将阅读者的认知水平理想化地提高到了与编码人员相同的层级,这有助于增进对代码的理解。

  • First  Crew Dragon launch was postponeddue  to  bad weather, 
  •          #  and  now we needan event  for  the  "second"   first  launch. 
  •          # Hence the stupidname. 
  •          classSecondFirstCrewDragonLaunch 
  •           ... 
  •           End  
  • 2.描述清晰

    有关pull request的描述为审查者提供任务最初的上下文,包括:

    • 标签的链接。
    • 对已完成事件的总结(如果不能从pullrequest的标题中看出)。
    • 相关pull request的链接(例如在另一服务中的相关变化)。

    不要把自认为理解代码需要的信息放在对pullrequest的描述里,应当进行代码注释:它们的效果更加显著,有助于未来代码阅读者的阅读。

    3.精简pull request

    这是一项强大的技术,谷歌甚至就小型pullrequest的益处单独写了一篇文章(https://google.github.io/eng-practices/review/developer/small-cls.html)。以下是笔者最喜欢的小型pull request的特点:

    • 审查更彻底
    • 审查更快捷
    • 更易合并(频繁的合并能减少冲突)
    • 如果被拒绝,浪费的精力更少
    完美代码不够的,如何做一个完美的Pull Request?" src="http://p3-tt.byteimg.com/large/pgc-image/c45bb9b527d34589a0668ca995cfb9ba?from=pc" width="554" height="36">

    4.快速回应审查

    处理审查注释通常比较费时,需要修复打字错误、添加遗漏的测试案例、对方法重命名等。如果你能快速完成,你的同伴就能花更少的时间来记忆与pull request相关的信息。

    但这种方法的缺点是会增加上下文切换的工作量,替代方法是使用番茄工作法(Pomodoro technique):每工作25分钟穿插一次短暂的休息。它能让人更专注、更有成效、更健康,并减轻疲劳度,休息后的上下文切换也会进行得更加自然。负面的破坏性影响虽然没有消失,但是会大大降低。

    5.给自己的pull request注释

    完美代码不够的,如何做一个完美的Pull Request?" src="http://p1-tt.byteimg.com/large/pgc-image/f316334d8f60461db31c70de42023672?from=pc" width="554" height="183">

    8.在实现功能之前讨论整体方法

    这可以省下很多时间。在要处理更复杂的重构和功能之前,先与同事讨论一下方法。与其他的开发人员讨论,解释这项任务和你的想法,他们也许会表示赞成,也许会提出更好的方法。

    很多时候笔者都面临着初步协调的缺失,好几天的工作成果白白浪费。想象一下你连续五天做一件事情,结果却听到“对不起,其实我们不需要……”想要把自己从失望中拯救出来,你得尽早获得反馈。

    未丽燕TEL:(010)68476606】

    以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

    查看所有标签

    猜你喜欢:

    本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

    ACM程序设计培训教程

    ACM程序设计培训教程

    吴昊 / 中国铁道 / 2007-8 / 28.0

    《ACM程序设计培训教程》不是这些专门问题的教科书,所以对这些问题所涉及知识的介绍不多,主要是分析一个个案例,介绍专属于ACM程序设计的方法和技巧。一起来看看 《ACM程序设计培训教程》 这本书的介绍吧!

    CSS 压缩/解压工具
    CSS 压缩/解压工具

    在线压缩/解压 CSS 代码

    随机密码生成器
    随机密码生成器

    多种字符组合密码

    HEX CMYK 转换工具
    HEX CMYK 转换工具

    HEX CMYK 互转工具