代码评审还能更好!

大家好,这里是架构资源栈 !点击上方关注,添加"星标",一起学习大厂前沿架构!

关注、发送C1即可获取JetBrains全家桶激活工具和码!

在开发者日常中,**代码评审(Code Review)**几乎是必不可少的环节。但你是不是也有过这样的抱怨:

  • GitHub 上堆叠 PR(stacked pull requests)和 interdiff review 支持太差?
  • 浏览器里点点点、写评语卡顿,还得忍受 HTTP 往返延迟?
  • 明明写代码用本地 IDE 爽得不行,评审却只能被迫"回到石器时代"?

TigerBeetle 的开发者就尝试过用一个小工具 git-review 来解决这些痛点,结果虽然没能一举成功,但留下了不少值得思考的火花。


GitHub 评审的两大硬伤

作者直言,自己对 GitHub(以及几乎所有代码评审系统)最不满的有两点:

  1. 评审状态不在仓库里存储 它们都依赖远端数据库,导致数据分散、依赖平台、延迟高。

  2. 评审强制远程优先,局限在浏览器界面 写代码大家都用本地 IDE,高效、顺滑、支持个性化工作流。可评审却要跑到网页里,打字还时常卡顿,体验极差。

相比之下,作者平时的本地评审流程是:

  • 把分支拉到本地
  • reset 到基准,让代码"像自己写的一样"
  • magit 浏览 diff 和源码
  • 本地跑测试、跳转定义、甚至直接试着改代码

这样的体验完全碾压浏览器。


git-review:把评审变成一个 commit

于是,git-review 应运而生。思路很简单:

  • 评审 = 一个 commit,挂在 PR 分支最上方

  • 里面包含了评语注释,例如:

    cpp 复制代码
    // CR(matklad): 这个判断是不是不够精确?
    // 要不要比较 `replica.view` 而不是 `header.view`?
    if (header.view != view) return;
  • 作者和评审者共同修改这个 commit

  • 评审结束时,加一个 revert commit 来保存评审历史

听起来很 hacker 风格,但用起来确实让人爽:评语直接嵌在代码里,就像 pair programming 一样直观。


为什么没能成功?

问题也很快暴露出来:

  • 冲突难搞:当作者改动底层 commit 时,评审注释(本质上也是代码)就会和 diff 发生冲突。
  • --force-with-lease 摩擦感大:频繁 rebase、强推,体验比预期更麻烦。
  • 评审和代码的"物理特性"不匹配:代码需要严格的哈希链一致性,而评审更适合宽松的冲突合并。

结果是:这个"500 行 hack"没能跑通,但却暴露了很多有价值的方向。


未来可能的解法

作者提到两个可能的希望:

  • Git 社区的 Change-Id 提案:或许以后能原生支持 per-commit interdiff review,让每次修改都能被追踪。
  • 存储与界面一体化:像 Gerrit 的 NoteDb、git-appraise、git-bug 那样,把评审状态直接塞进 git 里,真正本地化。

而 Jane Street 的内部系统,已经证明"更好的世界"是可能存在的,只是还没普及到大众开发者工具。


小D的思考

这次 git-review 实验虽然"败退",但给我们留下了一个启示:

👉 代码评审的未来,也许不是更花哨的网页界面,而是更本地化、更贴近开发者日常工作流的工具。

就像写代码没人会满足于 GitHub 网页编辑器一样,评审也迟早要回到本地 IDE,让开发者在同一个上下文里既能写代码,也能高效 review。

本文由博客一文多发平台 OpenWrite 发布!

相关推荐
橘子编程2 分钟前
经典排序算法全解析
java·算法·排序算法
z***3353 分钟前
SpringBoot获取bean的几种方式
java·spring boot·后端
aloha_78915 分钟前
联易融测开面试准备
java·python·面试·单元测试
s***469816 分钟前
【SpringBoot篇】详解Bean的管理(获取bean,bean的作用域,第三方bean)
java·spring boot·后端
动亦定1 小时前
页面导出大量数据导致响应超时解决方案
java·mysql
q***06291 小时前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
还是鼠鼠1 小时前
Redisson实现的分布式锁能解决主从一致性的问题吗?
java·数据库·redis·分布式·缓存·面试·redisson
d***95621 小时前
windows配置永久路由
java
王桑.2 小时前
IO流高级流--转换流
java
qq_12498707533 小时前
基于SpringBoot技术的企业请假审批管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·信息可视化·毕业设计