AICon上海|与字节、阿里、腾讯等企业共同探索Agent 时代的落地应用 了解详情
写点什么

如何做好 Code Review?

  • 2019-09-23
  • 本文字数:1481 字

    阅读完需:约 5 分钟

如何做好Code Review?

1. 背景

最近随着交易业务快速扩展,研发组内新项目及新成员越来越多,如何做好 Code Review,把控研发人员开发代码质量很是关键。


对于大部分业务团队,谈到 Code Review 就会面露哀状:


“上线时间倒排,研发工期这么紧,连码代码的时间都不够了,你还要我 CR?”


“上版的需求,这版就变了,代码生命周期太短,烂就烂吧,反正能用就行啦”

2. 抛出问题

下面分几个方面来分析下 Code Review:


  • Code Review 有没有用?

  • Code Review 中的问题如何解决?

  • 如何做好 Code Review?

3. 分析问题

1)Code Review 有没有用?


Code Review 的好处不言而喻。主要让你的代码可以更好的组织搭建,有更高可读性,且更容易维护,同时可以知识共享,相对而言,找 Bug 并不是那么的重要。


总结一句话,Code Review 可以直接影响你的工程能力。


2)Code Review 中的问题如何解决?


Code Review 中的主要问题:


编码质量较差


原因可能是对业务不熟悉,对语言应用技巧不熟悉,也可能对公司、部门编码规范不熟悉等等,有些问题如果没人及时提醒纠正的话,只会造成在错误的道路上越走越远。


自己承担还是指导他人?


Code Review 是一个学习过程,将自己的一些经验指导给新人,从长远来看,是在“复制”你的生产力,一个人能力再强,也不可能包揽所有的任务,团队协作也是研发人员需要注重培养的软素质。


主要 Review 什么?


编码风格,大家约定俗成的规范准则,从新人开始一步步坚持下去;


代码可读性,代码写出来是叫别人可以读懂的,而且是易读的;


全面性,业务实现异常情况考虑不全面的问题,需要老工程师指导,以免造成线上故障;


不良代码或架构,错误的代码实现、功能函数抽象以及文件组织等,都需要尽量保持整个代码库的风格一致。


3)如何做好 Code Review?


Code Review 机制一定是要与团队规模和项目节奏挂钩的。


Code Review 频次如何控制?


研发前期需要技术方案设计评审,日常 Code Review 保证开发过程中代码质量,研发完成后项目 Code Review 是为了呼应前期评审过的技术方案,确认哪些方案变更了,是由于什么原因等等。


如:大型项目,每天 Code Review 一次;小优化需求,merge request 时候 Code Review 一次即可。


Tips:Code Review 一定要尽可能前置,防止测试后改动问题造成影响。


Code Review 时间如何控制?


一次不要检查过多代码,控制在 1 小时以内,一个研究机构调查指出,太多信息或者 60 分钟以后,发现缺陷的能力就会降低。


作者在审核前需要注释源代码


在他人评审之前,自己 Review 一遍实现思路,说不定会有意外收获呢。


使用 Checklist


可能团队内人员会犯同样的错误,一遍遍重复查找费时费力,应该整理核对 Checklist 来缩减经常出现的错误的排查时间,同样 Checklist 也有利于问题统计和跟踪改进结论。


改进问题要及时


争取当天问题当天解决,同时 Code Review 新问题之前,先回顾一下之前遗留问题是否修复,做到 Code Review 行之有效。


培养积极的 Code Review 文化


Code Review 是团队提高代码质量的机会,也是互相学习的过程;建立接受他人评审的潜意识,我的工作产出是需要其他人 Review 的,这种自我激励会自然的要求自己产出更优秀的代码。

4. 写在最后

作为研发工程师,首先要对自己负责的业务和代码负责,这个与医生、教师的岗位职责是一样的。如果开发没有标准,对应该高标准的东西一味妥协,自己的标准一降再降,到最后吃亏的还是自己。


作者介绍:


张欢,平台交易事业部,2017 年 9 月加入贝壳找房,任职 PHP 资深研发工程师,目前负责交易 C 端 &内容库 &指标平台方向研发工作。


本文转载自公众号贝壳产品技术(ID:gh_9afeb423f390)。


原文链接:


https://mp.weixin.qq.com/s/Taze_uNtgZ7jI_qLnxgLDA


2019-09-23 08:002168

评论 1 条评论

发布
用户头像
作者可以聊聊怎么做好cr
2021-11-04 01:30
回复
没有更多了
发现更多内容

代码覆盖率最佳实践

数新网络官方账号

为什么大家都喜欢“人天”作为估算单位?

Bruce Talk

Scrum 敏捷开发 Agile

零代码零距离,明道云开放日北京站圆满结束

明道云

明道云在制造行业的五个实施案例与建议

明道云

浅谈Spark分布式计算

数新网络官方账号

Web3社交网络的另一种思路 - Oi! Network解析

股市老人

mybatis xml文件热加载实现

越长大越悲伤

mybatis springboot java

往往排查很久的问题,最后发现都非常简单。。。

艾小仙

Java kafka spring

Kotlin 学习笔记(二)—— 数据类、密闭类、循环写法以及常用集合操作符

修之竹

android kotlin

【Redis源码分析】Server启动过程

零点999

redis Redis 协议 Redis 核心技术与实战 Redis 数据结构 redis 底层原理

Kubernetes 简介及其调度原理

数新网络官方账号

pdf编辑工具:PDF Expert 中文激活版

真大的脸盆

Mac PDF Mac 软件 PDF编辑 pdf编辑工具

帮师姐把100个Excel中符合条件的数据,汇总到1个Excel里

程序员晚枫

Python Excel 自动化办公

Handler消息传递机制浅析

芯动大师

Activity Handler runOnUiThread

架构蓝图--软件架构的“4+1”视图模型

涛哥 数字产品和业务架构

软件架构 模型

矢量绘图UI设计:Sketch 95.3中文激活版

真大的脸盆

Mac UI Mac 软件 ui设计

面试高频问题之C++编译过程

小万哥

c++ 程序员 后端 编译 开发

压缩解压工具:Keka中文版

真大的脸盆

Mac Mac 软件 压缩工具 解压缩软件 解压软件

华为云ECS/HECS:中小企业上云第一步

IT科技苏辞

机器学习算法(五):基于企鹅数据集的决策树分类预测

汀丶人工智能

数据挖掘 机器学习 决策树

Elasticsearch简介以及索引原理

数新网络官方账号

关于GPT-4的产品化狂想

脑极体

AI

赠票 | 在北京,见证边缘的力量

俞凡

前缀和算法练习集

timerring

前缀和

QQ截图图片不够清晰解决方法

源字节1号

微信小程序 开源 软件开发

解决 Font '宋体' is not available to the JVM

源字节1号

微信小程序 开源 软件开发

如何选择合适的智慧公厕设备厂家?

光明源智慧厕所

智慧城市

CDC工具之Canal

数新网络官方账号

Flink CDC

数新网络官方账号

浅谈数据仓库工具——Hive

数新网络官方账号

CDC工具之Debezium

数新网络官方账号

如何做好Code Review?_文化 & 方法_张欢_InfoQ精选文章