博客
关于我
你亲手写的代码,正在出卖你。
阅读量:559 次
发布时间:2019-03-09

本文共 1351 字,大约阅读时间需要 4 分钟。

去年,我写过一篇文章:《》。今天,我这个十年老码农,再来写一篇我对代码的理解。

本号的读者,几乎都是程序员,代码是我们真正吃饭的家伙,但你是否知道,你亲手写的代码,正在出卖你。

在很多养宠物的人眼中,人是复杂的,宠物是简单的。同理,在程序员眼中,人是复杂的,但代码是简单的。一个人指责你有错,你不一定真的有错,人会撒谎,人有心计,但编译器不会!编译器向你报了一个错,那一定是你的代码有错。我是一个热爱思考的人,喜欢从代码中挖掘一些难以察觉的细节,久而久之,练就一番看代码识人的本领,只要看到一个人的代码,就能大概判断出这个人的技术水平和性格特质。

如果一份代码乍一看排版还挺整洁的,那它大概率是一份优秀的代码,作者也大概率是一名优秀或者有潜力的程序员,不过下面我们来说说反面教材。

如果一份代码换行不对齐,变量名充满了随意,比如a1、a2、func1、func2,那作者很可能只是想快速完成任务。如果一个文件中存在多个代码风格,那作者应该是把网上的代码直接粘贴过来,而且懒得进行格式化。这样的代码隐患很大,可能存在很多bug,凸显了作者急于完成任务的心理,在日常工作中,代码作者很可能是一个缺乏追求,工作中得过且过的人。

如果一份代码中,存在一个很长的函数,这个函数中完成了好几件事,所以函数名称也不太好取。要么是这种:fetchFromNetworkAndSaveToDatabaseAndShow(),包含了访问网络、本地存储和UI显示三个独立的模块;要么是这种:doWork(),因为作者也意识到函数名太长了不好,但太短的话又表达不了含义,算了,起个抽象点的名字吧!这表明作者的代码观念还停留在面向过程的阶段,写任何代码都想一气呵成,没有任何代码设计的考虑,作者往往基础知识欠佳,或者是刚毕业的大学生,缺少代码经验。

如果一份代码,存在过多层级的if/else和for嵌套,那只有两种可能:要么逻辑确实很复杂,要么代码作者逻辑奇特。我们可以顺着作者的逻辑读下去,如果觉得逻辑不顺畅,且存在冗余的判断,那这是一份糟糕的代码,作者很可能也缺乏理清复杂问题的逻辑思维能力。

如果一份代码没有任何注释,那说明这是一个正常的程序员,因为每个人都希望别人的代码写好注释,但自己的代码从不写注释。开车的朋友们都知道,车友中有一个名言:我讨厌加塞我的人和不让我加塞的人,二者有异曲同工之妙。但万一,你遇到了一个很喜欢写注释的程序员,那他一定是一个乐于助人的人,请务必好好保护他/她,因为这样的人太少,不保护的话容易灭绝。

然而,有一类爱写“注释”的程序员是需要抵制的。在代码的迭代过程中,他们喜欢对无用的代码进行注释,有时候也可能是为了下次方便使用,但久而久之,这份代码中就存在很多被注释掉的代码,如果别人去读这份代码,仿佛能感受到作者当时写代码那种纠结和摇摆不定的心情。也许这份代码并没有什么问题,但是看到那么多涂改的痕迹,却总是让人隐隐担忧:深夜11点,一个程序员,坐立不安,来回注释一些代码和调整参数,经过多次尝试,终于解决了一个难题,至于为什么能解决,谁也说不清!

那到底什么是好代码呢?大家可以看看著名开源框架的代码,看看别人的代码风格和行文逻辑,慢慢体会,总能掌握的。

本次分享就到这,我们下周再见。

转载地址:http://jpkpz.baihongyu.com/

你可能感兴趣的文章
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
mongodb定时备份数据库
查看>>
mppt算法详解-ChatGPT4o作答
查看>>
mpvue的使用(一)必要的开发环境
查看>>
MQ 重复消费如何解决?
查看>>
mqtt broker服务端
查看>>
MQTT 保留消息
查看>>
MQTT 持久会话与 Clean Session 详解
查看>>
MQTT工作笔记0007---剩余长度
查看>>
MQTT工作笔记0009---订阅主题和订阅确认
查看>>
Mqtt搭建代理服务器进行通信-浅析
查看>>
MS Edge浏览器“STATUS_INVALID_IMAGE_HASH“兼容性问题
查看>>
ms sql server 2008 sp2更新异常
查看>>
MS UC 2013-0-Prepare Tool
查看>>
MSBuild 教程(2)
查看>>
msbuild发布web应用程序
查看>>
MSB与LSB
查看>>
MSCRM调用外部JS文件
查看>>