这段时间看了王争的《设计模式之美》的课程。 个人觉得里面提到的谷歌 CodeReview 很有帮助。
正文中这样总结:
让国内大部分 IT 从业人士认识到 Code Review 的重要性,形成 Code Review 的技术文化,可能还需要一个漫长的时间。不过,我特别希望,你在学完专栏之后,能够意识到 Code Review 的重要性。有朝一日,当你成了领导,有了话语权、影响力之后,能够推动在团队、公司内进行 Code Review ,甚至为 Code Review 在整个国内技术圈中发扬光大贡献一份力量。
大家会有 Code Review 吗? 程度会到多少呢?范围会针对那些呢?
大概总结一下
对于中小公司来说 确实 Code Review 没太多价值,双赢的局面很难成型, 不如进一步压榨员工时间。
1
jedihy 2024-01-03 12:54:29 +08:00 3
什么?难道还有公司不做 code review 的?我见过的所有公司都要求至少一个 Approval 才能 merge PR 。
|
2
Maboroshii 2024-01-03 13:26:26 +08:00 via Android
不做,没空。要抓紧时间让代码跑起来
|
3
emSaVya 2024-01-03 13:29:56 +08:00
我都把 code review 放在 kpi 里作为工作的一部分了。怎么可能没有。
|
5
zylll520 2024-01-03 13:39:54 +08:00
必须有,在团队中必须推行 code review !
|
6
yujianwjj 2024-01-03 13:42:48 +08:00
要真正 code review 的话,至少懂别人的代码的业务。国内很多公司都是一个人干两个人的活,根本没这个精力管别人。
|
7
leehomyhh 2024-01-03 13:42:52 +08:00
以前有的,我领导会 review 我的代码,现在自己负责开发了,基本就是提交了扫一眼就过了
|
8
wlfeng 2024-01-03 13:43:27 +08:00
据我所知,小公司基本是没有的
|
9
zackzergzeng 2024-01-03 13:46:04 +08:00
code review 确实很有帮助,但是就是没时间,各种地方各种人都会催你尽快交付代码,能给你 review 代码的人也在忙着开发他的代码……
|
10
darkengine 2024-01-03 13:53:05 +08:00
IT 从业人士认识到 Code Review 的重要性有用吗,话事人认识到才有意义
|
11
yigecaiji 2024-01-03 13:56:11 +08:00 via Android
刚毕业没事会做,现在领导说我也不干,谁爱干谁干
|
12
coderzhangsan 2024-01-03 13:58:49 +08:00
中小型公司基本没有,测试没问题就直接上线了,code review 只是技术角度看方案设计,有一定的积极作用,由于国内中小型公司多数业务驱动,迭代频繁的话,早期的技术设计很可能不太适应,所以国内公司产品把关的重点仍然是测试环节,只要做好测试用例,可以规避 90%以上的较大的生产事故。
|
13
iceAD OP @coderzhangsan 这么看来,确实只适合大公司。
|
14
billzhuang 2024-01-03 14:24:00 +08:00
我觉得 code review 比 unit test 更重要,
如果非要二选一的话。 |
15
SeaTac 2024-01-03 14:26:48 +08:00 via iPhone 2
cr review 很看人
我遇到过极其 picky 一堆说是 nit comment 但是就是不给 approve 的 也遇到看都不看就 approve 结果上了 pipeline 才发现问题一堆 真正好的 cr reviewer 很少见 |
16
kneep 2024-01-03 14:28:19 +08:00 via iPhone
规则都很完善且复杂,但闭着眼睛打勾的人占多数
|
17
wu67 2024-01-03 14:28:59 +08:00
中小型没有.
反正我呆过的团队, 前端仔从一组一人两人到一组 8 人, 只有一家公司有, 而且是简单走查, 没有详细 review 到很具体的逻辑, 只是大致看看没有些智障写法就给过了. 还有一些是直接给我把 eslint 关掉的...从 origin pull 下来, 好家伙, 我本地 eslint 一堆红红黄黄的... |
18
28Sv0ngQfIE7Yloe 2024-01-03 14:32:42 +08:00
快速迭代的业务的迭代方向往往是核心逻辑的重写,这种业务往往不会有 PR/Merge 的流程
|
19
codingmiao 2024-01-03 14:34:21 +08:00 1
从刚进公司的转正报告开始,每次有和大领导汇报的机会我都要插一两页 PPT 说 CR 的事,方案、对比、收益都说过,每次领导都记下了下面就没了,哎。。之前我还在组内交叉 CR ,现在 C 个锤子,等出事了再说。
|
20
28Sv0ngQfIE7Yloe 2024-01-03 14:35:53 +08:00
|
21
BUHeF254Lpd1MH06 2024-01-03 14:41:49 +08:00
有 假的 CR
|
22
SeaTac 2024-01-03 14:43:53 +08:00 via iPhone
|
23
777777 2024-01-03 14:53:58 +08:00
所以别用国产,都是垃圾,没人 cr 的
|
24
Rache1 2024-01-03 15:10:48 +08:00
我们有,但是,我们的主要目的是减少低级错误,不怎么关注代码质量 🙇
|
25
mantouboji 2024-01-03 15:12:25 +08:00 1
Code Review 的质量度量:单位时间内听到的脏话次数。
|
26
paopjian 2024-01-03 15:14:24 +08:00
一个前端服务五个后端,改啥代码都是直接梭,爽翻
|
27
hongweijie8 2024-01-03 15:21:51 +08:00
小公司基本没有,review 最起码要懂业务,有的公司一个项目就一个前端一个后端,怎么 review
|
28
Quarter 2024-01-03 15:37:18 +08:00 via Android
现在项目太屎人手不够,一般人都是外包,写的很随便,没时间搞 code review ,只有 shit create
|
29
CaptainD 2024-01-03 15:51:25 +08:00
小公司,完全没有
|
30
liprais 2024-01-03 15:57:25 +08:00
水平都差不多的话能 review 出来个啥,就挑点回字有几个写法这种问题
|
31
zxf4399 2024-01-03 15:58:27 +08:00
有的
|
32
astray1988 2024-01-03 16:11:21 +08:00 2
来给个 DP , 某电商跟云的北美大公司,无论是做 design 还是 code , 都有相应的 review 机制。。如果是根据业务需求来添加小的 feature/功能,需要做 design ,然后组内跟相关组都有相应的 design review ,需要组里比较 senior engineer 来 sign-off ,如果是大的业务改动(例如开一个新的 business ,对应的 org 内部有 principle engineer 的 samurai design reviews 。。所谓的 code review ,每个组内部都有相应的 code review 机制,同时 org 内部标准也会对 code review 做一定的强制要求,例如提交的 CR/PR 的 Unit Test 必须 90%以上,还要通过各种所谓的 code quality test cases...具体到各小组/或者具体的 service ,code quality 也不一样,比较 legacy 的 service 会整体对 code review 松一些, 比较新的 service 会相对高些,例如每次做个新的 feature 还要写 integration tests 来保证 full CD
|
33
wojiaoxiaojuan 2024-01-03 16:17:41 +08:00
待过两家外企,都有 code review 流程。国内的小公司里,看同事 merge 就跟玩儿似的
|
34
crazyTanuki 2024-01-03 16:18:46 +08:00
没有 cr ,因为没有统一培训,代码风格各异,能跑就行
|
35
OneMan 2024-01-03 16:32:25 +08:00 1
code review 对当好螺丝钉有用,类似茴香豆有几种写法的检查。
对提高你的工资、职级,并没有鸟用。 |
36
burymme11 2024-01-03 16:35:12 +08:00
没时间 cr ,都是写业务,再大的公司也是 CRUD 占大头吧,中小公司就更是了,那怕每次都 cr ,时间久了,项目一样成屎山,因为需求一直迭代一直变的,业务越来越绕越繁琐,cr 的成本指数升高,而为了能过 cr ,开发写代码的成本也越来越高,死循环了。所以我司后来全面拥抱单元测试。
我觉的核心问题要解决垃圾的产品设计和业务架构,只要这两个合理,cr 真的就啥可过的。标题中正文部分,我个人觉的不太符合大清国情。 |
37
ren2881971 2024-01-03 16:35:39 +08:00
没卵用, 公司几十款产品,评审的人能清楚所有产品的业务逻辑么。。。 如果不清楚那 review 个毛线,只能为了提高存在感挑毛病。
|
38
dsggnbsp 2024-01-03 16:40:15 +08:00
我们是草台班子
|
39
urlpha 2024-01-03 16:45:19 +08:00 2
油管有个很有名的视频可以搜来看看。
“你看了,但是你对提交的具体内容并不关心。” |
40
flyv2x 2024-01-03 16:55:49 +08:00 1
国内小公司基本不重视技术文档和 Code Review 这些基本开发流程
|
41
zogwosh 2024-01-03 17:00:36 +08:00
cr 又不算产出谁干?我连 lint 都要关就为了早点搞完早点下班
|
42
28Sv0ngQfIE7Yloe 2024-01-03 17:07:28 +08:00
|
43
smirkcat 2024-01-03 17:10:14 +08:00
自己开发,自己看,bug 自己处理,有没有都一样
|
44
SoviaPhilo 2024-01-03 17:10:56 +08:00
@burymme11 解决不了的, 产品设计和业务架构是产品部门的护城河,怎么可能容你置喙
等业务功能一多,很多业务细节完全没人控的住的 比起 code review , 还不如有意识地推动领域驱动设计, 减少心智成本 |
45
Shanee 2024-01-03 17:11:05 +08:00 1
一直有 code review ,一般提交 review 之前先要通过工具保证一些基本的代码质量例如 sonar ,checkmax ,跑完 pipeline ,sonar 的覆盖率到 80%以上,checkmarx 没有问题,才能提 PR 给人去 review ,不同的 reviewer 会 review 粒度和力度都不同,会反复 comment-》 challenge-》 resolved
|
46
54xavier 2024-01-03 17:17:19 +08:00 3
|
47
nhhjhwiner 2024-01-03 17:17:54 +08:00
业务需求没,技术需求有
|
48
fqy12300 2024-01-03 17:21:07 +08:00
我一般都是自己写代码,自己测试,自己提交,自己合并,自己部署,自己发布。我还是挺相信我自己的。
|
49
Sigrdirfa 2024-01-03 17:25:25 +08:00
有点还是好的,至少能让大家知道你写了屎山,至少在 cr 变质之前可以有效防止大家写屎山。
|
50
iovekkk 2024-01-03 17:34:09 +08:00
不仅有,还接入了 CHATGPT4 ,AI Review 给出的内容,又详细又准确
|
51
MicroSharpAnt 2024-01-03 17:40:59 +08:00
上家公司有,而且觉得 leader 审核代码对我帮助很大。现在在一家小公司,从没 review 代码的,而且 git 大家都随便 push ,版本管理也很乱。不接手某些人的功能还好,一接手就觉得头疼,屎山就一点点堆积起来了
|
52
NoString 2024-01-03 17:45:51 +08:00
我一个人手上十几个项目,哪来人 review 。基本都处于随地大小便的状态
|
53
huyomi 2024-01-03 17:51:27 +08:00
上家公司有,被大佬 review 过代码提升会很大
|
54
twogoods 2024-01-03 17:54:43 +08:00
review 确实有这种感觉,其实真没必要的东西硬是要挑点出来,直接点不会显得你水平低
|
56
pkoukk 2024-01-03 18:22:52 +08:00
会看新来的应届生的,其它基本不看
|
57
magicls 2024-01-03 18:25:17 +08:00
cr 是基操吧,而且 google 还有 presubmit-verify 机制
|
58
darkengine 2024-01-03 18:34:27 +08:00 2
我左手一个 git merge ,右手一个 git push --force ,丝滑
|
59
somebody1 2024-01-03 18:45:40 +08:00
同一家公司干了六年了,code review 的次数没超过三次。
国内头部 to b 网络安全企业。 |
60
kingjpa 2024-01-03 18:50:20 +08:00 1
我代码都是 提交自动 webhook 到生产环境的,别说审查代码了, 我连 commit 都懒得写,每次回滚都是看时间
|
61
TideCC 2024-01-03 19:21:29 +08:00
现在一月,我们今年一年都知道要干啥活了,这个量谁给你 review
|
62
cabing 2024-01-03 19:36:59 +08:00
有时候简单 cr ,但是绝大部分时候都不能 cr 出问题,因为得深入到这个业务才行。
|
63
Xu3Xan89YsA7oP64 2024-01-03 20:04:47 +08:00
如果有标准,可以 lint 校验,如果没有标准,大家都是半吊子凭经验办事,没意义。
|
64
killergun 2024-01-03 20:07:02 +08:00 1
我就是那个要 review 的人,烦人的很
|
65
palxie 2024-01-03 21:13:02 +08:00
要 code review, 一般是我 review 别人的多点. 一般也是稍微看看, 有疑问讨论讨论, 但是别人 review 我的相对随便一点.
|
66
Helsing 2024-01-03 21:28:21 +08:00 via iPhone 1
前司有,还是很有用的,可以减少很多垃圾代码,提高代码的可维护性
|
67
jiangzm 2024-01-03 22:00:44 +08:00
我会 CR 团队成员的,但是也提倡大家相互 review ,特别是新业务功能没有跟进很及时的话 review 不出什么问题,所以相互 review 是有意义的。 当然有公共部分/重要部分修改大家会加上我或者只指定我 reivew 。
|
68
chiu 2024-01-03 22:09:31 +08:00
没有 CR approval 根本 merge 不了, 有些 repo 还需要 multiple CR approvals
|
69
houshuu 2024-01-04 00:05:05 +08:00
100% code review, 甚至 ci 改个参数都要 review.
一方面是老人可以传递经验, 同时也能检查一些比较特殊的设计下新代码带来的功能影响. |
70
zeromike 2024-01-04 00:08:09 +08:00
CR 是要建立氛围,形成团队对好代码、坏代码相对一致性的评判标准
如果 CR 只有流程,没有形成有效的成果的话,基本上有和没有没什么区别。毕竟代码自测+QA 都测过了,能有什么大问题吗 组件、工具类的还好说,对于业务代码,如果评审人在不熟悉业务的情况,很难评价,只能靠经验从代码共性上去发现问题,其实效果一般 |
71
zypy333 2024-01-04 00:13:58 +08:00 1
小公司,我们没有,但我会看别人的,但是只看看不说
ps ,有没有互相 review 的网站?有时候自己写的拿不定主意,想让人帮忙提提意见,不过这家公司除了我没人在乎代码质量 |
72
imycc 2024-01-04 03:07:09 +08:00
视具体人力而定。如果有专门的研发团队,且涉及多人协作的,那一定要有相应的流程规范。现在在一家大厂,围观研发团队的开发工作。几十个人共同开发一个项目,每天早上都要开 CR 会,安排了几个资深的研发来把关。
我之前在一个四五个人的开发小组里面,每周上线前也会做内部 CR 。但后来去一家中小公司,就我跟另一个半桶水的同事,我会给他 CR ,但他给我 CR 就不指望了。有时候也挺无助的。 |
73
kangyue9999 2024-01-04 05:35:16 +08:00 via Android
没有 CR 的公司是不是也没有测试?所以最后就是一坨答辩?开发到一定程度就变成不停在造 bug 和修 bug 。然后一单有人离职这代码他的部分多半有可能别人就没法维护了。。。
|
74
Hyvi 2024-01-04 06:34:40 +08:00 via iPhone 1
很重要,but 投入和价值远比不上业务带来价值呀
|
75
neroxps 2024-01-04 07:49:46 +08:00 via iPhone
哈哈哈 我司可能测试都不全。写完就上线。boom 了就现场顶住客户的怒火
|
76
kinghly 2024-01-04 07:53:25 +08:00 via Android
我基本都会 review 的,有问题必须改完才会通过。
|
77
yzbythesea 2024-01-04 08:06:01 +08:00 1
CR 是基操吧。。。“没时间” 写 CR ,感觉就像没时间擦屁股一样滑稽。
|
78
JounQin 2024-01-04 08:45:32 +08:00 via iPhone
曾经给团队的小朋友的 MR 提过一个最后回复超过 100+ 的 review ,不知道他恨不恨我。
放一个可以公开的正在进行中的 PR review ,目前已经有 50+ conversation 了。 |
79
JounQin 2024-01-04 08:47:33 +08:00 via iPhone 1
@Hyvi 磨刀不误砍柴工,很多人/公司不懂这个道理,好的代码扩展性很强、维护成本低很多,不能光顾着眼前的一丁点儿时间。
|
80
JounQin 2024-01-04 09:26:14 +08:00 via iPhone 1
|
81
luzemin 2024-01-04 09:26:23 +08:00 1
有,至少 2 个 approval 才能 merge 。
不过因为各种原因,仍然还是有一些问题: 1. 小团体,我提了代码我想快速 merge ,那我就私下找关系好的开发,“帮我 review 下”言下之意“帮我点一下 approval ” 2. 随便一个 story/task ,都会修改很多文件,review 只能粗看 3. 加了新的 solution ,不是所有人对原有的业务一清二楚,所以基本上 review 一些规范上的问题,很少 review 实现上的逻辑组织和代码复用等问题。 |
82
thomas15425 2024-01-04 09:50:30 +08:00
公司没有 code review ,就连 Test 都没有,写完直接 push 就行。现在那代码是十几年的屎山,bug 还一大堆。公司完全没有要重构的意思,还有往里加新功能。
之前的人不用的代码直接注释掉就完事。 有些代码只写了函数的外壳,里面没有代码。 写一大堆没有用的变量 非必要的指针有大堆,内存溢出也不管 index 有些由 0 开始,有些由 1 开始。 代码的金字塔能建到 7-8 层 |
83
UIXX 2024-01-04 09:51:11 +08:00
以前做现在不做,一是投入产出比的问题,二是无法做到有效 CR 。
具体情况是,研发有各人的专业窄道,不是同样方向同等水平的研究者很难看懂对方的代码,也谈不上什么 CR 了。 |
84
assad 2024-01-04 10:05:31 +08:00 1
别人业务都做了好几轮了,你这个还没 review 完。还得看情况而定
|
85
zeromake 2024-01-04 10:05:42 +08:00
和上面的兄弟说的一样,没法做有效 cr ,业务一复杂,一个 pr 就是 30-50+ 文件变更,然后再加上你完全不知道同事在写的业务是什么(最多知道他写的业务叫什么),能看出什么东西呢?看什么语法注释各种规范标准?这种东西能总结出来应该完全可以做成 lint ci 工具了,根本轮不到人看……
|
86
rocksolid 2024-01-04 10:10:37 +08:00
不理解 review 的意义,除非通用功能,否则你能指望另一个同事跟了几周几月的逻辑你几个小时弄懂么,代码质量规范可以用 sonar 之类的
|
87
Promtheus 2024-01-04 10:10:47 +08:00
做是要做的,但是有点形式主义。感觉做了和没做也没啥区别。也就找找写法错误优化优化 很少回去看架构设计。review 的人也是抱着完成任务的态度。凑几个点提交完事。逼近这个花太多时间也不会给自己加钱,谁愿意认真看别人的代码呢
|
88
fredweili 2024-01-04 10:13:27 +08:00
有,这东西不是平等的,就是有经验的帮没经验的挑错
|
89
unco020511 2024-01-04 10:20:42 +08:00
有,我们是合代码之前必须有两个人点,不过基本都不会看得很仔细
|
90
Torpedo 2024-01-04 10:28:04 +08:00
cr 这种和你的项目、组织架构息息相关。
cr 相当于让另一个人理解一遍你的代码。 付出最多的是另一个不做你需求的人,无形中要求这个需求的人数增加 但是实际很多项目都是只有一个人负责,没有关系他做了什么。只要他交付需求就可以了 这样的组织架构显然不可能有什么有效的 cr 相反,比较基础、核心的组件开发设计都有多人共同维护,这样 cr 才有基础 |
91
bzw875 2024-01-04 10:32:38 +08:00
没见过不做 code review 的公司,除非小作坊、小公司。我们还做 ESlint ,还要写接口要写测试用例
|
92
zw1one 2024-01-04 10:46:08 +08:00
作为负责人的角色,我会要求组员开发前讲解下代码设计,设计上没问题就行了。
新来的小朋友我会 review 一下他的代码,或者叫同事盯一下,免得挖坑。 合作比较愉快的同事,没必要 review ,太形式了,代码设计聊好就行了。 |
93
MEIerer 2024-01-04 10:52:34 +08:00
有没有 code review 得看公司有没有规范吧,正好国内的公司很多都是草台班子,不 review 也是正常的
|
94
hevi 2024-01-04 10:52:48 +08:00
我所在小公司,连需求都没 review:D
|
95
bajitanglang 2024-01-04 11:00:54 +08:00
一句话,老板要某某时间就上线.
|
97
JounQin 2024-01-04 13:02:19 +08:00
@rocksolid 我 review 代码从来不看具体业务是什么,这跟我没关系,我只管写出来的代码是不是解耦优雅,至于你说的 sonar lint 那些只能解决很少的代码异味,更重要的是编码思维。
|
99
JackSlowFcck 2024-01-04 13:24:25 +08:00
@darkengine
说到点上了,得生意人认识到才有用,毕竟谁会在乎资源的想法? |
100
superchijinpeng 2024-01-04 13:28:32 +08:00
每一个 Merge Request 都要 Code Review
|