代码是灵魂,注释是心声

开发 前端
在以前一些关于代码注释的文章中,我发现,你不需要的注释才是最好的注释。不要急着批判,请允许我阐述一下。首先代码应该尽量地简洁,尽可能地做到不需要依赖注释就可以理解。只有那些真的没法更易于理解的代码,才需要我们添加注释。

在以前一些关于代码注释的文章中,我发现,你不需要的注释才是***的注释。不要急着批判,请允许我阐述一下。首先代码应该尽量地简洁,尽可能地做到不需要依赖注释就可以理解。只有那些真的没法更易于理解的代码,才需要我们添加注释。

有一本非常经典的书叫《Structure and Interpretation of Computer Programs》(《电脑程序的结构和编译》),最初发表于1985年,在序言中就表明其观点:

程序必须能便于我们阅读,让机器执行只是附带的。

Knuth也在他1984年发表的经典论文《Literate Programming》(《文学编程》)中秉持了类似的观点:

我们应该转变传统的思维,程序不再是告诉计算机做什么的指令,而是向人类描述如何让计算机做事情的文字,编程像写文章一样。

文学编程关注的主要是展现精致的风格。程序员应该像作家一样,认真地选择变量名,并解释每个变量的意思,努力写出易于人脑理解的程序。

如果你写出来的代码,既能被其他程序员理解又能成功编译,那么需要添加注释的地方肯定就不会很多。关于使用注释作为辅助工具,下面就是一个颇具代表意义的例子:

这段代码取自一个已经使用多年、闭源了的系统。

  1. float _x = abs(x - deviceInfo->position.x) / scale; 
  2. int directionCode; 
  3. if (0 < _x & x != deviceInfo->position.x) { 
  4.     if (0 > x - deviceInfo->position.x) { 
  5.         directionCode = 0x04 /*left*/; 
  6.     } else if (0 < x - deviceInfo->position.x) { 
  7.         directionCode = 0x02 /*right*/; 
  8.     } 

上面的代码等同于下面的代码,但是下面的代码可读性更高。

  1. static const int DIRECTIONCODE_RIGHT = 0x02
  2.  
  3. static const int DIRECTIONCODE_LEFT = 0x04
  4.  
  5. static const int DIRECTIONCODE_NONE = 0x00
  6.  
  7. int oldX = deviceInfo->position.x; 
  8.  
  9. int directionCode = (x > oldX) ? DIRECTIONCODE_RIGHT : (x > oldX) ? DIRECTIONCODE_LEFT : DIRECTIONCODE_NONE; 

需要注意的是,注释的越多并不意味着代码的理解性更强。当然在本案例中并没有涉及到这一点。上面的注释——如果你注意到的话——使得代码更加显得凌乱不堪。有时候,注释得越精简代码的可读性才越高。特别是在你必须更换使用其他符号名的情况下。

虽然我们能无限次地重构和精简代码以避免写繁冗的注释,但是表述自己的思考过程的方式却是有局限性的。

无论***你呈现的代码是有多么的简洁和清楚,代码也不可能完全自文档化。但是代码永远也不可能取缔注释的存在。正如Jef Raskin所说:

[代码]无法解释如此写程序以及选择该方法的原因。从[代码]上我们也看不出选择某些替代方法的理由。例如:

  1. /* A binary search turned out to be slower than the Boyer-Moore algorithm for the data sets of interest, thus we have used the more complex, but faster method even though this problem does not at first seem amenable to a string search technique. */ 

在A开发人员看来完全显而易见的东西,可能在B眼里完全就像雾里看花一样。所以我们在写注释的时候,也要考虑到这一点:

下面这个可能你一清二楚

  1. $string = join('',reverse(split('',$string))); 

反转字符串,但是要如何才能插入到

  1. # Reverse the string 

Perl文件中呢?

的确,这一点都不难。归根究底,代码只会告诉你程序是如何工作的,但是注释则能说明工作的原因。所以,下次你写代码的时候,不妨在这两个方面给你的同事做个榜样。

译文链接:http://www.codeceo.com/article/code-and-comment.html
英文原文:Code Tells You How, Comments Tell You Why
责任编辑:张伟 来源: 码农网
相关推荐

2018-12-19 17:20:17

2012-06-20 10:01:55

开源云计算

2020-06-02 07:44:04

AQS JavaNode

2009-08-10 08:52:23

Windows 7企业部署新特性

2019-11-19 10:32:55

Java语言程序员

2020-12-21 14:46:56

代码开发程序员

2009-06-11 17:37:32

EJB注释

2019-03-29 08:12:54

嵌入式系统物联网硬件物联网

2015-03-16 13:09:12

微软Windows AzuISV

2013-07-12 10:24:46

IBM2013技术峰

2015-07-29 11:27:28

大数据时代数据分析统计学

2015-08-17 09:43:08

2013-09-11 09:43:06

苹果安卓

2011-09-05 10:30:51

重构代码库业务模型

2011-01-19 10:13:20

FaceBook代码业界

2020-09-08 12:51:35

低代码开 发代码平台

2015-11-10 09:09:23

代码程序员成长

2022-10-19 11:17:35

2020-11-03 10:12:34

低代码程序开发编码

2018-01-02 13:30:04

代码质量代码预言
点赞
收藏

51CTO技术栈公众号