高效进行代码回顾(Code Review)

WTF/m

代码回顾是帮助团队养成编写高质量代码的习惯的手段之一。


1. 代码回顾应该...

  • 尽早发现代码中存在的问题,并进行修复。
  • 提高代码的可读性,降低理解成本,进而降低维护成本。
  • 在团队内传播知识,分享经验,互相学习。
  • 建立团队代码规范的约定,督促团队养成良好的编程习惯。

❓实现的逻辑错误如何来发现


2. 代码质量

“代码”包括了代码仓库中的所有文件(资源、配置、脚本、文档...)

2.1 可读的代码

一致的代码样式--保持一致避免代码合并频繁冲突,提升阅读代码的舒适度:

  • 制表符 还是 空格
  • 缩进
  • 换行
  • 驼峰 还是 下划线 还是...
  • 注释
  • ...

代码风格本身不影响代码含义,但影响阅读的舒适度,不一致的风格容易产生合并冲突

💡Tips

  • 将 IDE 的代码风格配置导出,提交到代码仓库
  • 养成随时格式化代码的习惯,或设置保存文件时自动格式化
  • 参考

有意义的命名--准确地表达代码的意图,包括业务上的意图(功能)和设计上的意图(架构、模式)

💡Tips

  • 使用翻译工具来命名英文变量:https://github.com/xudaolong/CodeVar
  • IDE 拼写错误提示
  • 遵循业界流行的命名约定(getter/setter、from/to...)
  • 考虑非技术人员的可读性要求(可以作为活文档的测试命名,图片等设计资源)
  • 自己团队达成的一致命名规范记录到 Wiki 或者仓库中的 README

2.2 优雅的代码

代码坏味道--发现代码之中潜在问题的信号

常见代码坏味道

Android Lint Checks:https://sites.google.com/a/android.com/tools/tips/lint-checks

💡Tips

  • 从 TOP3 的代码坏味道开消除:重复代码、过长方法、过大类
  • 约定团队自己的阈值(方法最大行数、类最大行数、允许重复代码出现的次数)
  • 利用 Code Inspection 发现问题并修正
  • 自己编写 lint 检查

2.3 模块化的代码

(反)模式--识别可以复用的代码“套路”,不符合整体架构的代码。

  • 测试模式:GWT(3A)、Mock
  • 设计模式:23 种 GoF 模式(部分)
  • 架构模式:类的职责分类,类之间应该如何交互,如 MV*
  • 架构风格:粗粒度的代码组织方式,如整洁架构、响应式风格、组件化、插件化

💡Tips

  • 团队选择自己的架构风格和架构模式,记录到 Wiki 或者仓库中的 README
  • 将设计模式提取成模块(类、包、库)进行复用

3. 回顾的形式

XP反馈环

3.1 编写时回顾

在第一时间发现代码中的各种问题,并进行修正。

💡Tips

  • 结对编程以及 TDD 编写代码
  • 随时在 IDE 中格式化代码
  • 通过 Code Inspection 发现问题并修正
  • 通过命令行 lint 发现问题并修正

3.2 提交前交叉回顾

确保原子提交,提交的代码不是“半成品”。

💡Tips

  • Reviewer 提前了解业务上下文(故事卡),便于理解 Author 的讲解
  • 期交前运行自动化测试
  • 提交前通过 IDE 格式化代码
  • 提交前通过 Code Inspection 发现问题并修正
  • 提交前通过命令行 lint 发现问题并修正
  • 使用 githook 自动完成检查
  • 发现问题立即重构

3.3 集成前交叉回顾

PR 强制交叉回顾,确保集成到主干上的代码符合代码规范。跨地域、跨团队协作,无法及时面对面进行交叉回顾时采用。

💡Tips

  • 流水线静态扫描验证
  • 流水线自动化测试验证
  • Author 向 Reviewer 提供更多业务上下文(故事卡)

3.4 集成后集体回顾

定期(每周至少3次)对重点代码进行集体回顾,分享业务知识、技术知识和设计知识。

💡Tips

  • 团队中新人很多时、有重大技术重构时,提高回顾的频率
  • 提前公布要回顾的代码涉及的业务上下文(故事卡)
  • 参与回顾的成员事先熟悉上下文
  • 控制回顾的时间(不超过1小时)和代码量(200~300行)
  • 回顾前确保环境安全,让大家可以畅所欲言
  • 对事不对人,多鼓励少批评
  • 回顾之前先对上一次集体回顾的改进项进行跟踪
  • 发现问题讨论出改进项(评论、技术卡等等)
  • 可以让 Author 以外的成员来讲解
  • 主持人控制好时间,不要没完没了的讨论
  • 回顾发现的问题要记录下来,落实下来进行跟踪

5. 小结

无时无刻、无处不在

响应变化、持续优化

build-quality-in-legacy-system.jpg

6. 参考:

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容

  • 一、关于 lint 对于已经搭建CI开发环境的团队来说,代码规范管理必然会成为团队协作的基石。但人工的CodeRe...
    superYang0033阅读 1,968评论 0 2
  • 使用 Lint 检查改进您的代码 除了通过构建测试来确保您的应用符合其功能要求之外,还务必通过 Lint 运行代码...
    ArcherZang阅读 753评论 0 1
  • 1 背景 一个项目开发必然会涉及团队协作,而工程质量就需要团队去保证。一般我们期望的代码:无潜在风险、无重复逻辑、...
    zyl06阅读 3,202评论 5 16
  • 成功的秘诀在于少犯错。 -完- ©严正法律声明 本文版权受我国相关法律及适用之国际公约中有关著作权法律的保护,为中...
    更好时代阅读 184评论 0 0
  • #自律给你自由#Day80 【运动】 跑5公里 【成长】 英语132 体态练习 【日常】 今日来到了 九年前来的地...
    阿吉哦阅读 44评论 0 0