为什么要code review

打印 上一主题 下一主题

主题 705|帖子 705|积分 2115

1. 简介

本文将介绍 Code Review的相关内容,包含为什么要Code Review,以及Code Review主要review哪些部分的内容,之后讲述如何才能形成一套比较好的Code Review规则和流程。后续讲述了Code review中一些可以遵守的比较好的规则,最后讲述了如何才能让Code review流程跑起来。
本文为最近了解code review相关内容的总结,有问题/有建议可以在评论区帮忙指出,感谢!!!
2. 为什么要code review

代码审查(Code Review)是现代软件开发团队中非常重要的一环,因为它可以带来以下几个方面的好处:

  • 提高代码质量: 通过代码审查,开发团队可以及时发现和修复代码中的问题,包括代码中的错误、潜在的安全漏洞、缺陷和性能问题等,从而提高代码的质量。
  • 减少维护成本: 通过及时发现和修复问题,代码审查可以降低后续维护成本,因为修复问题的成本通常比在后期修复更低。
  • 加强知识共享和团队协作: 代码审查可以帮助团队成员了解项目中其他成员的工作,从而促进知识共享和团队协作,提高团队整体的开发能力。
  • 提高编码规范和标准的遵守: 通过代码审查,可以促进团队成员遵守编码规范和标准,统一团队的代码风格和代码质量要求,提高代码可读性和可维护性。
  • 促进开发者的技能提升和成长:代码审查可以帮助开发者了解项目中的技术细节和最佳实践,从而促进开发者的技能提升和成长。
总之,代码审查可以帮助开发团队提高代码质量和开发效率,降低维护成本,提高团队协作和开发者技能,从而在软件开发项目中发挥重要作用。
3.review哪些部分的内容呢

Code Review整个流程中,比较重要的一个节点,是对代码进行Review,然后指出代码中可能存在的问题。具体主要关注哪些代码问题,应该是每个团队,在实践中总结出适合自己的一套规范。这里大概说明一些通用的Code Review可能需要关注的内容。
3.1 代码结构


  • 代码的组织结构:代码应该按照一定的组织结构进行编写,例如按照功能模块进行组织、按照层次结构进行组织等等。在审查代码结构时,应该关注代码的组织结构是否清晰、是否符合设计原则等方面。
  • 模块化和可重用性:代码应该具有一定的模块化和可重用性,以便于代码的复用和维护。在审查代码结构时,应该关注代码是否具有可重用的模块、是否具有良好的接口设计等方面。
  • 代码的层次结构:代码应该按照一定的层次结构进行编写,例如分为界面层、业务逻辑层、数据访问层等等。在审查代码结构时,应该关注代码的层次结构是否清晰、是否具有良好的模块划分等方面。
3.2 代码逻辑

代码逻辑Review主要 包括条件分支、循环结构、异常处理、错误处理等方面的实现是否合理。

  • 条件分支的检查。 判断条件是否覆盖了所有可能的情况,是否有重复的判断条件是否有不必要的嵌套。
  • 循环结构的检查。 检查循环是否能够正常终止,是否存在死循环,是否有更简洁的循环方式。
  • 异常处理的检查。 是否对所有的错误进行正确的处理,是否提供合适的错误提示,是否能够记录错误日志等。
3.3 代码的可读性和可维护性

Review代码时,需要关注代码的可读性和可维护性,包括代码的命名、注释、缩进、代码段的长度、函数和方法的参数和返回值等方面。

  • 命名应该清晰,简洁,准确。代码中的变量、函数、类等命名应该具有清晰、简洁、准确的特点。而不是简单的字母或数字,且应该使用一致的命名方式,避免混淆。
  • 注释应该清晰、准确地描述代码的含义和作用。不应该重复代码,也不应该存在无用的注释。注释应该保持最新状态,以便后续维护。
  • 代码段的长度合适。:通常情况下,代码段的长度应该保持在一个比较合理的范围内,以保证代码的可读性。一些通用的建议是,每个函数或方法的长度应该控制在 100 行以内。
  • 函数和方法的参数和返回值规范。 函数和方法的参数应该尽量少,入参和出参较多的情况下,可以考虑使用DTO来封装。函数和方法的返回值应该尽可能明确,避免使用不必要的返回值或无意义的返回值。
  • 避免使用魔法数字或魔法字符串。
3.4 代码的可靠性


  • 入参合法性检查。 是否对输入参数进行了合法性检查,避免出现意外的输入错误。
  • 单元测试检查。 是否进行了足够的单元测试,并且能够覆盖各种边界情况。
3.5 代码的可测试性


  • 可测试检查。 代码是否容易编写测试用例,测试用例是否易于理解和维护。
  • 单元覆盖率检查。 测试覆盖率是否足够,是否存在测试漏洞或者未考虑到的场景。
4. 制定cr的规则和流程是什么呢


  • 确定团队的目标和需求
  • 确定code review的规则和流程

    • code review的时间安排,确定审查时机,以及时间安排
    • 确定每次审查的代码量
    • 确定审查的内容: 定义一份可用的checklist,确保审查者可以根据标准和指导进行 review。
    • 确定用于进行 code review 的工具和环境
    • 确定审查后需要进行修改的代码如何重新提交,如何跟踪意见的处理过程。

  • 开始实施
  • 收集和分析数据

    • 收集数据

      • 收集问题类型和解决方式的数据,例如代码问题的类型、解决方式、处理时间等

        • 记录代码问题,如代码可读性等内容
        • 记录问题的处理时间
        • 对问题进行分类

      • 收集code review的时间安排/代码量

        • 收集每次code review的代码量
        • 收集开始code review的时机
        • 每次code review耗时,包含开发和reviewer的耗时
        • 对项目发布是否有影响


    • 数据分析

      • 根据数据记录结果,获取到code review经常出现的问题

        • 添加代码静态扫描规则,扫描出通用问题,减少code review问题
        • 进行对应的分享,完成团队内的知识共享

      • 对code review的耗时进行分析,来改进流程

        • 不同需求类型,每次code review的代码量是否合适
        • code review开始的时机是否合适
        • code review是否对项目发布造成影响,在排期过程中,是否增加对code review的考虑
        • 对reviewer的工作安排是否受到影响,有的话,如何解决


    • 效果分析

      • 代码质量的提升: 通过比较一段时间下来,发现的问题数量是否减少


  • 规则和流程的优化
5. 可以遵守的比较好的code review的准则


  • 每个提交的代码必须经过代码审查,以确保代码的质量和可维护性。
  • 在代码审查之前,开发人员应该对自己的代码进行一次自审查,确保代码没有明显的错误和问题。
  • 按照确定的规则进行审查:遵循指定的审查标准和流程,以确保一致性和准确性。
  • 代码审查应该专注于发现代码中的问题和缺陷,而不是对开发人员进行评价或指责。
  • 不要强制修改:审查人员应该将自己的建议视为建议而非命令,并与开发人员进行协商。
  • 在代码审查中,开发人员应该积极参与讨论,提出自己的观点和想法,并接受他人的反馈和建议。
  • 代码审查应该在合适的时间进行,以避免影响开发进度和项目交付时间。
  • 代码审查结果应该被记录下来,并及时修复和追踪问题,确保问题得到解决和修复。
6. 如何让code review跑起来

6.1 通过checklist来做code review

通过checkList来做code review似乎是一个比较好的方式,下面是开发者和reviewer的一个checkList的示例。
6.1.1 开发者的checklist


  • 需求评审需要邀请reviewer参加
  • 代码被审查前,自己先review一遍
  • 需要提前和reviewer协调好代码review的时间
  • 每次合并代码前都需要通过代码审查
  • 代码有必要做单元测试的位置,已完成单元测试的覆盖,单元测试已通过
6.1.2 reviewer的checkList


  • 需要review的代码,需要参加需求评审/测试用例评审
  • 需要预先留出code review的时间,排期时确定
  • 代码review根据审查标准执行

    • 每次合并代码是否通过代码审查
    • 代码结构是否符合规范
    • 代码逻辑是否存在问题
    • 代码是否具有一定的可读性
    • 代码单元测试用例是否覆盖充分

  • 代码review需要记录问题类型,方便统计数据
6.2 限制 Code Review 时间

限制单次code review的时间,能够避免待review的代码量过多,如果一次待review的代码量过多,此时整个流程很容易流于形式。因此,这里可以根据不同团队的实际情况,定义好单次code review的耗时,限制在一个时间范围内。
6.3 代码静态扫描规则的建立

对于一些常见的代码review的问题,可以制定代码扫描规则,在code review之前,先执行一次代码扫描,识别出其中比较常见的问题,减少代码review的时间。
这样对于也减轻了reviewer的负担,也利于开发者自行发现问题,自行解决,避免时间的浪费。
6.4 学习和分享

团队中的成员可以定期分享 Code Review 的经验和技巧,以便更好地提高审查的效率和质量。
有这样一个分享,那么code review这个过程可以作为一个输入,能够增加大家code review的参与度。
6.5 反馈和改进

code review的流程,在执行过程中,大概率会发现其中并不合理的地方,或者有待改进的地方,此时应该每隔1个月/2个月,来回顾整个流程,发现其中不合理的地方,让code review更好得进行下去。
同时,在code review过程中,也有收集一些code review的数据,可以对其进行分析,发现其中不合理的地方,针对不合理的地方进行改进。
7. 建立code review的流程的实践过程

7.1 确定团队目标

首先,团队建立code reviwe的目标和需求,为什么要code review,有目标了,后续才能评估code review是否达到了目的。
7.2 时间节点的确定

首先需要确定code review的时间节点的安排。是开发完成后,提测前开始code review还是其他时间节点呢。code review的时间安排是否包含到项目排期中。
reviewer是否得提前知会,在何时知会? 其是否要参加需求评审以及测试用例评审等项目相关需求的评审会? 以及reviewer在code review过程的所耗工时要怎么统计呢,是不是在项目排期时,也需要考虑到code review的耗时,然后耗时大致的排期,是否设定为开发时间的10%,还是其他,是否先执行,后续再根据实际情况调整呢?
7.3 review平台以及review形式的确定

上面code review的时间安排已经确定好了,之后便需要开始code review,这里需要团队内确定code review的工具,是使用开源工具,如reviewBoard,亦或者是直接gitlab平台提交mr的时候顺便review呢,这个也需要确定。
当平台确定好之后,我们需要确定review的形式,是开发和reviewer一起review,reviwer一边看一遍提问,亦或者是reviewer先整体看一遍,然后有疑问再提出,然后开发再当面说明,或者是其他形式,这个也是需要确定的。
7.4 review代码量的确定

之后比较重要的点,便是每次review的代码量的问题,我们可以想象,如果每次需要review的几千行的代码,此时往往review便会流于形式,其实并不会起到太大的作用。这里应该由团队内部协商好code review的形式,是单次少量,多次review; 还是项目开发完成之后,再整体review; 或者是两者的结合,一些项目整体开发完成之后再review,一些项目采取单次少量,多次review的形式,亦或者是其他。
7.5 review内容的确定

接着,就要开始代码review,这里就需要确定review主要review哪些内容,这个示例可以参考第三点所说的,review哪些部分的内容,不过还是需要团队自行确定。不过这里有个前置依赖,团队需要有一套统一的代码规范,如命名规范等。这里假设已经确定review的内容包含代码的可读性,如果没有一套统一的规范,review流程是比较难执行下去的。
7.6 数据收集方式确定

到这里,我们可以算是完成了一次code review的流程,但是一个流程如果只有执行,没有回顾,那是不太合适的,所以对于code review的流程是需要定时回顾的。当进行回顾时,需要有数据来做支撑的,才能识别出整体流程是否存在不合理的地方,那数据从哪里来呢?那只能从每次代码review的过程中获取。
所以,这里也需要定义每次review流程中,需要记录下来一些内容,方便后续回顾,具体记录的内容,可以参考第四点制定cr的规则和流程是什么呢 中第四点的内容,然后数据记录的方式也可以统一一下,比如使用飞书文档或者多维表格,亦或者是其他形式来存储。方便后续回顾使用。
7.7 code review如何更好得执行

当上面的内容都确定好之后,在我看来,一个code review的流程其实就已经完成了,这个时候便可以考虑如何让code review整个流程跑得更顺畅,这里可以参考第六点如何让code review跑起来中的内容,比如使用checkList来减轻心智负担,其次可以建立静态扫描规则集,能够减少code review的工作量等。
7.8 定时回顾

然后再定时回顾整个code review的流程,发现其中不合理的地方,再对其进行改进。
8. 总结

该文档是一篇关于Code Review的输出,介绍了Code Review的规则和流程需要包含的内容,以及具体需要Review的内容。此外,还描述了一些在Review过程中需要遵守的原则,如尊重,建议等,以保持Review的积极性和有效性。
最后,列举了一些方式,如定期进行Review、使用静态代码扫描工具、checklist来进行code review,进行学习和分享,能够让Code Review更好地执行下去。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

傲渊山岳

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表