`

五种应该避免的代码注释

阅读更多

酷壳: http://CoolShell.cn/

原文: http://coolshell.cn/?p=2746


在酷壳,有很多文章都提到了代码注释,如:《十条不错的编程观点》、《优质代码的十诫》、《整洁代码的4个提示》、《惹恼程序员的十件事》等等。今天,某国外的程序员在这里列举五种应该避免的程序注释,我觉得比较有道理,但我觉得有少数几个观点也并不绝对。所以,我把原文的这五种应该避免的程序注释罗列在下面,并放上原作者和我的个人观点作为比较。希望对大家有用。

一、自恋型注释
(注:原文为Proud,我觉得“自恋”更好一点)

public class Program
{
    static void Main(string[] args)
    {
        string message = "Hello World!";  // 07/24/2010 Bob
        Console.WriteLine(message); // 07/24/2010 Bob
        message = "I am so proud of this code!"; // 07/24/2010 Bob
        Console.WriteLine(message); // 07/24/2010 Bob
    }
}原文:这样的程序员对于自己的代码改动非常骄傲和自恋,所以,他觉得需在在这些自己的代码上标上自己的名字。其实,一个版本控制工具(如:CVS或Subversion)可以完整地记录下所有的关于代码的改动的和作者相关的一切信息,只不过不是那么明显罢了。

陈皓:我同意原文的观点。在我的团队里也有这样的事情发生。有段时间我认真思考过这样的事情,是否应该把这样的事情在代码中铲除出去。后来,我觉得,允许这样的行为并不一定是坏事,因为两点:

调动程序员下属的积极性可能更为重要。即然,这种方式可以让程序员有骄傲的感觉,能在写代码中找到成就感,为什么要阻止呢?又不是什么大问题。
调动程序员的负责任的态度。程序员敢把自己的名字放在代码里,说明他对这些代码的信心,是想向大家展示其才能。所以,他当然知道,如果这段他加入的代码有问题的话,他的声誉必然受到损失,所以,他敢这么干,也就表明他敢于对自己的代码全面的负责。这不正是我们所需要的?!
所以,基于上述考虑,我个人认为,从代码的技术角度上来说,这样的注释很不好。但从团队的激励和管理上来说,这样的方式可能也挺好的。所以,我并不阻止也不鼓励这样的注释。关键在于其是否能有更好的结果。

二、废弃代码的注释
public class Program
{
    static void Main(string[] args)
    {
        /* This block of code is no longer needed
         * because we found out that Y2K was a hoax
         * and our systems did not roll over to 1/1/1900 */
        //DateTime today = DateTime.Today;
        //if (today == new DateTime(1900, 1, 1))
        //{
        //    today = today.AddYears(100);
        //    string message = "The date has been fixed for Y2K.";
        //    Console.WriteLine(message);
        //}
    }
}原文:如果某段代码不再使用了,那就应该直接删除。我们不应该使用注释来标准废弃的代码。同样,我们有版本控制工具来管理我们的源代码,在版本控制工具里,是不可能有代码能被真正的物理删除的。所以,你总是可以从以前的版本上找回你的代码的。

陈皓:我非常同意这样的观点。只要你是废弃的,就应该是删除,而不是注释掉。注释并不是用来删除代码的。也许你会争论到,在迭代开发中,你觉得被注释的代码很有可能在未来会被使用,但现在因为种种问题暂时用不到,所以,你先注释着,然后等到某一天再enable它。所以你注释掉一些未来会有的程序。在这样的情况,你可以注释掉这段代码,但你要明白,这段代码不是“废弃”的,而是“临时”不用的。所以,我在这里提醒你,请不要教条式地在你的程序源码中杜绝这样的注释形式,是否“废弃”是其关键。

三、明显的注释
public class Program
{
    static void Main(string[] args)
    {
        /* This is a for loop that prints the
         * words "I Rule!" to the console screen
         * 1 million times, each on its own line. It
         * accomplishes this by starting at 0 and
         * incrementing by 1. If the value of the
         * counter equals 1 million the for loop
         * stops executing.*/
        for (int i = 0; i < 1000000; i++)
        {
            Console.WriteLine("I Rule!");
        }
    }
}原文:看看上面的例子,代码比注释还容易读。是的,大家都是程序员,对于一些简单的,显而易见的程序逻辑,不需要注释的。而且,你不需要在你的注释中教别人怎么编程,你这是在浪费时间去解释那些显而易见的东西。你应该用注释去解释你的代码功能,原因,想法,而不是代码本身。

陈皓:非常同意。最理解的情况是你的代码写得直接易读,代码本身就是自解释的,根本不需要注释。这是最高境界。注释应该说明下面的代码主要完成什么样的功能,为什么需要他,其主要算法怎么设计的,等等。而不是解释代码是怎么工作的。这点很多新手程序员都做得不够好。别外,我需要指出的是,代码注释不宜过多,如果太多的话,你应该去写文档,而不是写注释了。

四、故事型注释
public class Program
{
    static void Main(string[] args)
    {
       /* I discussed with Jim from Sales over coffee
        * at the Starbucks on main street one day and he
        * told me that Sales Reps receive commission
        * based upon the following structure.
        * Friday: 25%
        * Wednesday: 15%
        * All Other Days: 5%
        * Did I mention that I ordered the Caramel Latte with
        * a double shot of Espresso?
       */
        double price = 5.00;
        double commissionRate;
        double commission;
        if (DateTime.Today.DayOfWeek == DayOfWeek.Friday)
        {
            commissionRate = .25;
        }
        else if (DateTime.Today.DayOfWeek == DayOfWeek.Wednesday)
        {
            commissionRate = .15;
        }
        else
        {
            commissionRate = .05;
        }
        commission = price * commissionRate;
    }
}原文:如果你不得不在你的代码注释中提及需求,那也不应该提及人名。在上面的示例中,好像程序想要告诉其它程序员,下面那些代码的典故来自销售部的Jim,如果有不懂的,你可以去问他。其实,这根本没有必要在注释中提到一些和代码不相干的事。

陈皓:太同意了。这里仅仅是代码,不要在代码中掺入别的和代码不相干的事。这里你也许会有以下的争辩:

有时候,那些所谓的“高手”逼着我这么干,所以,我要把他的名字放在这里让所有人看看他有多SB。
有时候,我对需求并不了解,我们应该放一个联系人在在这里,以便你可以去询问之。
对于第一点,我觉得这是一种情绪化。如果你的上级提出一些很SB的想法,我觉得你应该做的是努力去和他沟通,说明你的想法。如果这样都不行的话,你应该让你的经理或是那个高手很正式地把他的想法和方案写在文档里或是电子邮件里,然后,你去执行。这样,当出现问题的时候,你可以用他的文档和邮件作为你的免责证据,而不是在代码里干这些事。

对于第二点,这些需求的联系人应该是在需求文档中,如果有人有一天给你提了一个需求,你应该把其写在你的需求文档中,而不是你的代码里。要学会使用流程来管理你的工作,而不是用注释。

最后,关于故事型的注释,我需要指出也有例外的情况,我们团队中有人写注释喜欢在注释或文档里写一些名人名言(如 22条经典的编程引言,编程引言补充,Linus Torvalds 语录 Top 10 ),甚至写一些小笑话,幽默的短句。我并不鼓励这么做,但如果这样有利于培养团队文化,有利于让大家对工作更感兴趣,有利于大家在一种轻松愉快的环境下读/写代码,那不也是挺好的事吗?

另外,做为一个管理者,有时候我们应该去看看程序员的注释,因为那里面可能会有程序员最直实的想法和情绪(程序员嘴最脏??)。了解了他们的想法有利于你的管理。

五、“TODO”注释
public class Program
{
    static void Main(string[] args)
    {
       //TODO: I need to fix this someday – 07/24/1995 Bob
       /* I know this error message is hard coded and
        * I am relying on a Contains function, but
        * someday I will make this code print a
        * meaningful error message and exit gracefully.
        * I just don’t have the time right now.
       */
       string message = "An error has occurred";
       if(message.Contains("error"))
       {
           throw new Exception(message);
       }
    }
}原文:当你在初始化一个项目的时候,TODO注释是非常有用的。但是,如果这样的注释在你的产品源码中出现了N多年,那就有问题了。如果有BUG要被fix,那就Fix吧,没有必要整一个TODO。

陈皓:是的,TODO是一个好的标志仅当存在于还未release的项目中,如果你的软件产品都release了,你的代码里还有TODO,这个就不对了。也许你会争辩说,那是你下一个版本要干的事。OK,那你应该使用项目管理,或是需求管理来管理你下一个版本要干的事,而不是使用代码注释。通常,在项目release的前夕,你应该走查一下你代码中的TODO标志,并且做出决定,是马上做,还是以后做。如果是以后做,那么,你应该使用项目管理或需求管理的流程。

上述是你应该避免使用的注释,以及我个人的一些观点,也欢迎你留下你的观点!

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/haoel/archive/2010/08/02/5782907.aspx

分享到:
评论

相关推荐

    eclipse代码注释风格

    在编程世界中,代码注释风格是至关重要的,它不仅提高了代码的可读性,也有助于团队协作和代码维护。Eclipse是一款广泛使用的Java集成开发环境(IDE),它...因此,每位Java开发者都应该重视并遵循良好的代码注释规范。

    Doxygen代码注释规范.docx

    Doxygen 代码注释规范 Doxygen 是一种开源跨平台的,以类似 JavaDoc 风格描述的文档系统,完全支持 C、C++、Java、Objective-C 和 IDL 语言,部分支持 PHP、C#。Doxygen 可以从一套归档源文件开始,生成 HTML 格式...

    leveldb代码注释.zip

    它采用了Log-Structured Merge Tree(LSMT)作为主要的数据结构,这是一种针对磁盘I/O优化的树形结构。LSMT将写入操作序列化,并在后台进行合并,从而减少了随机写入,提高了读写效率。 1. Memtable:内存中的键值...

    注释的艺术

    ### 注释的艺术:详解代码注释的重要性与技巧 在编程领域,代码的可读性和维护性是评判软件质量的关键标准之一。《注释的艺术》一文深入探讨了编写高质量注释的方法与原则,旨在帮助程序员提升代码的清晰度,减少...

    C#编程规范,可以直接做为开发规则使用,包括代码注释,声明,命名等规范

    这些规范涵盖了代码注释、声明、命名等多个方面,旨在提高团队合作效率,降低理解和修改代码的难度。 ### 第一章 概述 #### 规范制定原则 1. **一致性**:所有代码应遵循同一套规范,避免因个人习惯导致的不一致。...

    如何写好代码-注释.pptx

    2. **保持注释与代码同步更新**:当代码发生改变时,相应的注释也应该随之更新,避免出现过时的信息。 3. **使用主动语态**:尽可能使用主动语态而非被动语态,使注释更加直接明了。 4. **注重注释的质量而非数量**...

    Android音乐动态频谱显示demo(点击频谱区域可改变频谱样式共5种) 代码有注释

    7. **代码注释**: - 提供的代码有注释,这对理解代码逻辑、学习和调试都非常有帮助。注释通常会解释关键函数的作用、变量的用途以及重要逻辑步骤。 8. **版本兼容性**: - 考虑到Android系统的碎片化,开发者...

    千万要避免的五种程序注释方式小结

    以下是需要避免的五种程序注释方式: 1. **高傲的程序员**:这类程序员会在每行代码后面加上自己的名字,如`// 07/24/2010 Bob`,这不仅显得多余,而且无法提供实质性信息。版本控制系统如Git能够追踪代码更改记录...

    ot:ThinkPHP源代码注释

    《深入理解ThinkPHP框架:源代码注释解析》 在当今的Web开发领域,PHP作为后端编程语言占据着重要地位,而ThinkPHP框架作为PHP的代表性框架之一,深受开发者喜爱。本文将深入探讨ThinkPHP的源代码注释,帮助读者更...

    请避免五种程序注释方式

    你是否曾在检查代码时碰到一条在你看来多余的注释?在代码中使用注释的目的是提升代码的可读性,以让那些非原始代码开发者能更好地理解它们。  我甄别出5类让我不胜其扰的注释及5类生成它们的程序员。我希望读过...

    less语法小结-源代码+注释.rar

    本文将基于“less语法小结-源代码+注释.rar”这个压缩包中的内容,深入探讨Less的重要特性,包括变量、混合、继承以及数学运算。 一、Less变量的常见用途 Less中的变量允许开发者为颜色、尺寸、字体等常用属性设置...

    JAVA编程注释规范详解

    例如,对代码的注释应该放在其上方或右侧,而不是下方。避免在代码行的末尾添加注释,因为这会使代码更加难以阅读。对于变量声明的注释,可以在行尾添加,并保持所有行尾注释的对齐。 5. **注释的数量** 注释的...

    html怎么注释?.docx

    HTML 注释是 HTML 代码中的一种特殊语法,用于在代码中添加注释,以便于代码的阅读和理解。下面将详细介绍 HTML 注释的使用和注意事项。 一、HTML 注释代码与语法 HTML 注释以 `&lt;!--` 开头,`--&gt;` 结尾,中间添加...

    Java注释规范整理.pdf

    在软件开发过程中,代码注释扮演着极其重要的角色。良好的注释不仅有助于提升代码的可读性和可维护性,还能促进团队成员之间的有效沟通。然而,关于Java注释的具体规范却常常缺乏明确的标准,导致开发者在实践中难以...

    如何执行Java代码审查

    4. 使用代码注释:使用注释来解释代码的意图和实现细节,提高代码的可读性和维护性。 二、安全清单项分类 1. 权限限制:程序应运行在保证功能正常的最小权限模式下,限制类和成员的可访问性。 2. 输入校验:对输入...

    软件开发代码规范 C#版本

    * 代码注释:每个函数、方法、类和变量都应该包含一个代码注释,用于描述其作用和使用方法。 三、 排版规范 排版规范是指代码的排版和格式规范,以下是排版规范的具体要求: * 缩进:使用四个空格的缩进方式,...

    java注释模板eclipse

    Eclipse作为一款强大的Java集成开发环境,提供了一种自定义和自动化注释的功能,使得开发人员能够快速生成一致、规范的代码注释,从而提高代码的可读性和可维护性。 一、Java注释模板的类型 1. 文件头注释:通常...

    java初学者完整代码+注释4

    Java编程语言是面向对象的、跨平台的编程语言,对于初学者来说,它提供了一种易于理解的结构,使得学习编程变得更加容易。本资源“java初学者完整代码+注释4”是专为那些刚刚接触Java的人设计的,旨在帮助他们逐步...

    Java开发者的十大戒律.pdf

    本文总结了十大戒律,涵盖了代码注释、复杂度控制、代码简洁性、硬编码避免、框架选择、错误处理、代码重用、代码优化、代码review和单元测试等方面。 一、为代码加注释 代码注释是指在代码中添加注释,以便其他...

Global site tag (gtag.js) - Google Analytics