自下向上地编写容易阅读的代码(上)

2017 年 8 月 17 日 开源中国 闲大赋


点击图片报名参加广州&珠海源创会


我在 《关于极简编程的思考》 中曾提到要编写可阅读的代码。因为代码是编写一次,阅读多次。 阅读者包括代码编写者,以及后来的维护人员。能让阅读代码更轻松,有利于增强项目或者产品的可维护性。

本博客分为上下俩部分,第一部分讲解在代码层次 编写可阅读的代码, 第二部分讲解方法,类,以及一些设计上的考虑 让代码更适合阅读。这些都是我在实际工作的一些体会以及代码审查过程中跟同事一起得出的一些经验。没有太高深的理论,适合所有人借鉴交流。


if 语句保持主流程畅通


使用if语句,对于不符合主逻辑的,要尽早返回,这样可以减轻代码阅读者的负担,下次再看,直接就可以从主逻辑开始。直接跳过不关心的代码块(这样代码块必然返回都是fasle) 如下是一个不好的例子

在主逻辑前面分别返回了true 或者 false,阅读者会造成混乱,因为说明这个方法任何一处都有可能返回不同的情况,更糟糕的是

显然这段代码会造成较大的阅读负担


尽可能多地去掉代码行的注释



显然,有多行是无用的注释,如果当初为了调试保留在这里,那么调试成功后要尽快删除,不要给后来人留下疑惑。

代码注释会随时过时,但IDE并没有像代码那样能充分管理注释,不需要的注释应该立即删除,如下注释刚开始看起来不错


项目中,状态值会随着项目发展而不断增加,上面的注释会误导阅读者以为性别只有俩个状态,正确的做法是

这样,阅读者可以通过枚举类找到性别对应所有的状态,比如 Gender.Male,Gender.FEMALE,Gender.UNKNOWN


使用一些中间变量来增强代码可读性



上面的代码一气呵成,且只用了一行,但没有下面的代码更容易阅读

看似其他人一行代码完成似乎更牛,你用了多行代码才完成了一个功能,但你的代码显然更容易被后来人阅读。我一直觉得写代码就跟写小说一样,要看得懂才是真正的小说,如果从任何地方切入都能看懂,那就是本好小说。

甚至可以将一部分代码封装到一个方法里,通过方法名和参数来提高可阅读性。后来者虽然第一阅读到这样的代码还需要进入方法体了解用法,但下次再次阅读,或者再次修改,就可以跳过他已经熟悉的方法,比如如下解析excel的文件,需要读出多个片段数据


如上parse方法将分成三个方法完成,这对于性能和代码行数,可能略有影响(其实根本算不上影响),但增强了代码的可阅读性,如果后来人重构了用户积分部分,可以直接修改readUserCreditInfo方法,而不需要从上百行代码里找到自己应该修改的地方。


提倡使用一些短小方法来划分代码



这段代码如果单独看尚可,如果这是在成百行代码的一部分,建议放到一个小方法里,比如,重构为

重构后,代码阅读者每次看到这里,都会放心的跳过这部分代码。因为从方法名已经了解其作用,能很快的扫过这片代码区域


不要使用数组


程序里的数组只适合代码编写者看,阅读者无法判断数组代表的业务含义,比如

较好的方法是定义一个对象代替数组

也许你觉得调用后立刻转化成有意义的参数名会不影响阅读,这确实是一种补救办法,但不及CallResult好。代码编写者应该能时刻想到给阅读者减轻负担。

类似的列子还有JPA的查询,对于不能映射为实体的,总是返回一个数组,比如


返回这样一个数组,如果sql要改写,那么代码对array的的处理也肯定要修改。看代码的人也不得不阅读这些无聊的代码。

相对于MyBatis和我写的BeetlSql,这一点JPA就不行了-提供了一个返回数组的查询接口。

我发现我每次在博客提到我写的开源,就有人说我想宣传自己的开源。我想强调一下,我只是践行知行合一,我不会轻易评判一个我不熟悉领域技术,除非我真的实践过。如果喷子对此不爽,你大可以忽略我“自我宣传部分”,仅看到我博客其他内容。


不一定要取有意义的变量名


java 里的for循环一般都是使用i变量,这说明了有些情况下,可以用一些简单的变量名字代替有意义的变量名字。前提是这些名字约定俗成,或者能在阅读代码的人眼里,这个变量就是几行之内就使用完毕,比如


success 变量可能不如paySuccess更好,但鉴于很快使用完毕,还是可以接受。相反,如果在sucess变量定义后面的100行,还用到了这个变量,那么“success” 就可能让人疑惑了,代码阅读者不得不再翻回去了解success的含义


总结


代码是一次写入,多次阅读,从代码层次去看待如何编写容易阅读代码,可能还能列出更多的规则,我个人觉得这些规则并不重要,重要的是能时刻想到后来人会如何阅读你的代码才是最重要的,如果他阅读你的代码,毫无障碍的达到一目十行,觉得你写的代码没什么高深,那就是好代码。

博文参考了 王垠的《编程的智慧》


更多干货请前往公众号菜单栏“读我”->热门资讯”查看。



推荐阅读

六大理由告诉你为什么 GNOME 仍然是最好的 Linux 桌面环境

还不知道这 11 个超酷的编程新工具你就 out 了!

Xshell 多版本存在后门,或上传用户服务器账号密码

eBay 开源项目推荐

点击“阅读原文”查看更多精彩内容

登录查看更多
0

相关内容

【实用书】学习用Python编写代码进行数据分析,103页pdf
专知会员服务
194+阅读 · 2020年6月29日
专知会员服务
146+阅读 · 2020年6月15日
干净的数据:数据清洗入门与实践,204页pdf
专知会员服务
161+阅读 · 2020年5月14日
《代码整洁之道》:5大基本要点
专知会员服务
49+阅读 · 2020年3月3日
【书籍推荐】简洁的Python编程(Clean Python),附274页pdf
专知会员服务
180+阅读 · 2020年1月1日
【书籍】深度学习框架:PyTorch入门与实践(附代码)
专知会员服务
164+阅读 · 2019年10月28日
PC微信逆向:两种姿势教你解密数据库文件
黑客技术与网络安全
16+阅读 · 2019年8月30日
已删除
AI掘金志
7+阅读 · 2019年7月8日
GitHub 热门:别再用 print 输出来调试代码了
Python开发者
27+阅读 · 2019年4月24日
【收藏】支持向量机原理详解+案例+代码!【点击阅读原文下载】
机器学习算法与Python学习
10+阅读 · 2018年9月13日
实战 | 40行代码实现人脸识别
七月在线实验室
3+阅读 · 2018年3月7日
无需一行代码就能搞定机器学习的开源神器
人工智能头条
6+阅读 · 2017年11月7日
带你训练一个简单的音频识别网络(附代码)
数据派THU
4+阅读 · 2017年10月9日
Mesh R-CNN
Arxiv
4+阅读 · 2019年6月6日
Next Item Recommendation with Self-Attention
Arxiv
5+阅读 · 2018年8月25日
Arxiv
6+阅读 · 2018年5月18日
Arxiv
5+阅读 · 2018年1月23日
Arxiv
27+阅读 · 2017年12月6日
VIP会员
相关VIP内容
【实用书】学习用Python编写代码进行数据分析,103页pdf
专知会员服务
194+阅读 · 2020年6月29日
专知会员服务
146+阅读 · 2020年6月15日
干净的数据:数据清洗入门与实践,204页pdf
专知会员服务
161+阅读 · 2020年5月14日
《代码整洁之道》:5大基本要点
专知会员服务
49+阅读 · 2020年3月3日
【书籍推荐】简洁的Python编程(Clean Python),附274页pdf
专知会员服务
180+阅读 · 2020年1月1日
【书籍】深度学习框架:PyTorch入门与实践(附代码)
专知会员服务
164+阅读 · 2019年10月28日
相关资讯
PC微信逆向:两种姿势教你解密数据库文件
黑客技术与网络安全
16+阅读 · 2019年8月30日
已删除
AI掘金志
7+阅读 · 2019年7月8日
GitHub 热门:别再用 print 输出来调试代码了
Python开发者
27+阅读 · 2019年4月24日
【收藏】支持向量机原理详解+案例+代码!【点击阅读原文下载】
机器学习算法与Python学习
10+阅读 · 2018年9月13日
实战 | 40行代码实现人脸识别
七月在线实验室
3+阅读 · 2018年3月7日
无需一行代码就能搞定机器学习的开源神器
人工智能头条
6+阅读 · 2017年11月7日
带你训练一个简单的音频识别网络(附代码)
数据派THU
4+阅读 · 2017年10月9日
相关论文
Mesh R-CNN
Arxiv
4+阅读 · 2019年6月6日
Next Item Recommendation with Self-Attention
Arxiv
5+阅读 · 2018年8月25日
Arxiv
6+阅读 · 2018年5月18日
Arxiv
5+阅读 · 2018年1月23日
Arxiv
27+阅读 · 2017年12月6日
Top
微信扫码咨询专知VIP会员