写不好代码注释?这份注释指南一定要收好!

敏捷开发
• 阅读 634

之前有读者问,自己一直不明白如何写出合理的代码注释。

这也是不少程序员一直头疼的问题,比如接手新代码时,没有注释,完全搞不清逻辑;自己写的注释,跟不上代码修改,成了误导;复杂逻辑不知道咋注释,别人也看不懂。

写不好代码注释?这份注释指南一定要收好!

(听君一席话,听了一席话)

网上也有很多关于代码注释的段子,搞笑中透露着真实的注释现状,比如下面这些注释:

写不好代码注释?这份注释指南一定要收好! (这也算得上是“风险预警”吧 ↑ )

写不好代码注释?这份注释指南一定要收好! 写不好代码注释?这份注释指南一定要收好! 写不好代码注释?这份注释指南一定要收好!

(阅读代码的人,心里一定很崩溃 ↑ )

还有一种是,注释透露着一种自由的随意感 :

写不好代码注释?这份注释指南一定要收好!

我们都知道,注释是代码的重要组成部分,它能够为代码的读者提供额外的信息,帮助他们更好地理解代码的功能、逻辑和设计意图。

写出合理的注释不仅能够提高代码的可读性和可维护性,还能促进团队成员之间的有效协作。

本文就将一些经验分享给大家,希望提供一些帮助。

一、明确注释的目的

目标设定理论提出:清晰、明确和可衡量的目标比模糊不清的目标更能提高工作效率。目的也同样。

而我们写注释的主要目的是为了增强代码的可理解性。下面列出了一些具体的注释目的,在写之前帮助我们理清思路,明确行动方向。

(一)解释代码的功能和用途

代码注释要让读者能够快速了解一段代码或一个函数的整体作用。比如,编写了一个函数用于从数据库中获取特定用户的信息,注释就可以这么写:“此函数用于从数据库中检索指定用户的详细信息,包括用户名、电子邮件和年龄等字段。”

实践要点

  • 在注释中明确函数的输入和输出格式,例如数据类型、结构等。
  • 提及函数可能抛出的异常或特殊情况。

    (二)说明复杂算法或逻辑的工作原理

    对于复杂的计算或独特的逻辑流程,注释能够帮助读者理解代码背后的思路。比如,对于一个使用递归实现的斐波那契数列计算函数:
  def fibonacci(n):
    """
    此函数使用递归算法计算斐波那契数列的第 n 项
    参数:
    n (int): 要计算的项数
    返回:
    int: 斐波那契数列的第 n 项值
    工作原理:
    欧几里得算法的基本思路是:不断用较小数除以较大数,并将余数赋给较小数,直到余数为 0。
    在本函数中,如果 n 小于等于 0,返回 0;如果 n 等于 1,返回 1;
    否则,返回 fibonacci(n - 1) + fibonacci(n - 2),通过递归计算得出结果
    """
    if n <= 0:
        return 0
    elif n == 1:
        return 1
    else:
        return fibonacci(n - 1) + fibonacci(n - 2)
实践要点:
  • 对于复杂的算法,绘制简单的流程图或架构图,并在注释中引用。
  • 解释算法中的关键变量和它们的变化规律。

    (三)提供关于特定变量、函数或类的重要信息

    解释变量的含义、函数的输入输出以及类的设计目的等。比如:“这个变量 max_attempts 表示尝试连接数据库的最大次数。”

假设我们有一个函数用于计算两个数的最大公约数:

  def greatest_common_divisor(a, b):
    """
    此函数用于计算两个整数的最大公约数
    参数:
    a (int): 第一个整数
    b (int): 第二个整数
    返回:
    int: 两个数的最大公约数
    算法: 使用欧几里得算法,其基本步骤为:用较大数除以较小数得到余数,然后将较小数作为新的较大数,余数作为新的较小数,重复此过程,直到余数为 0,此时的除数即为最大公约数
    """
    while b!= 0:
        a, b = b, a % b
    return a

在示例中,就注释清晰地说明了函数的功能、参数和使用的算法。

实践要点:
  • 对于类,注释中描述其继承关系、主要方法和属性。
  • 对于函数,说明函数的性能特点,例如时间复杂度和空间复杂度。

    二、保持简洁明了

    注释应该简洁而准确地传达关键信息。避免过于冗长和复杂的描述,以免增加读者的理解负担。例如,不要写一大段文字来解释一个简单的函数,而可以简洁地说:“此函数计算两个整数的平均值,并返回结果。”
在这里,提供一些实践技巧:
  • 提炼关键信息,去除不必要的修饰词和废话。
  • 对于简单的逻辑,用一句话概括注释。
  • 定期审查注释,删除冗余和过时的信息。
  • 对于较长的注释,将其拆分成多个短句或段落,增强可读性。

三、采用清晰的语言

使用简单、易懂的词汇和句子结构,避免使用行话、缩写或过于技术化的术语,除非你确定读者一定能理解。所以尽量简单表达,就像在与其他开发者进行交流一样。举个例子,当你在解释一个数据结构时,“这是一个基于链表实现的队列”的表达可能会比说“这是一个采用链表数据结构的 FIFO 队列”更容易被人理解。

在这里,需要注意以下事项:
  • 保持语言的一致性,避免在同一项目中使用多种表述方式来表达相同的概念。
  • 对于可能有歧义的术语,进行必要的解释。
  • 建立项目词汇表,统一关键术语的表述。
  • 对于新引入的技术术语,在注释开头进行定义和解释。

    四、提供上下文

    注释不仅要描述代码本身,还要让读者了解它在整个程序中的位置和作用。还是举个例子:“此函数在用户登录流程中被调用,用于验证用户输入的密码是否正确。” 这样的注释很明显能够帮助读者将当前代码与程序的更大框架联系起来,帮助读者更快理解代码。

为了更好理解和掌握,我们来假设一个场景:我们现在有一个处理订单的模块,其中有一个函数用于计算订单的总价:

  def calculate_order_total(order_items):
    """
    此函数在订单处理流程中用于计算订单的总价
    参数:
    order_items (list): 包含订单中各项商品信息的列表,其中商品信息以字典形式存储,包括'price'(价格)和'quantity'(数量)两个键
    注意: 此函数会根据商品的'price'和'quantity'进行计算
    """
    total = 0
    for item in order_items:
        total += item['price'] * item['quantity']
    return total

这里的注释就明确了函数在整个订单处理流程中的位置和作用。

实践要点:
  • 引用相关的业务流程文档或需求说明,增强注释的上下文信息。
  • 在注释中提及与当前代码相关的其他函数或模块。

    五、遵循统一的风格

    在整个项目中,要保持注释的格式、标点和命名约定的一致性。这包括注释的位置(行末、函数前等)、注释的符号(例如 Python 中常用的 # )、以及注释的书写方式(是完整的句子还是短语等)。统一的风格可以使注释看起来更加整洁和专业。

例如,在一个 Python 项目中,规定函数注释采用如下格式:

  def some_function(arg1, arg2):
    """
    函数功能的简要描述
    参数:
    arg1 (数据类型) - 参数 1 的描述
    arg2 (数据类型) - 参数 2 的描述
    返回:
    返回值的数据类型 - 返回值的描述
    """
    # 函数体代码
提供一些风格规范的思路:
  • 确定统一的注释符号和格式。
  • 制定关于注释内容的详细规范,如参数描述、返回值描述的格式。
  • 使用工具(如代码规范检查插件)来自动检查注释风格的一致性。
  • 为新加入项目的开发者提供详细的注释风格指南。

六、注释关键代码

重点注释那些容易引起混淆、不常见或对程序的正确性和性能有重要影响的部分。对于简单和直观的代码,或许不需要过多注释,但对于复杂的条件判断、循环结构或与外部系统的交互部分,详细的注释是很有必要的。还是以例子来直观解释下:

  def process_data(data):
    """
    此函数处理传入的数据
    参数:
    data (列表) - 包含待处理数据的列表
    以下的条件判断用于处理不同的数据类型
    如果数据是整数列表,执行求和操作
    如果数据是字符串列表,连接所有字符串
    """
    if all(isinstance(item, int) for item in data):
        total = 0
        for num in data:
            total += num
        return total
    elif all(isinstance(item, str) for item in data):
        result = ''
        for string in data:
            result += string
        return result
实践要点:
  • 分析代码的复杂度和易错性。
  • 关注与业务逻辑紧密相关的核心代码部分。
  • 对于关键代码,添加注释说明其优化的思路和考虑的因素。
  • 在关键代码的注释中引用相关的技术文档或最佳实践。

七、及时更新注释

随着代码的修改和更新,相应的注释也必须保持同步。过时或不正确的注释可能会比没有注释更糟糕,因为它们会误导读者。在修改代码时,务必检查并更新相关的注释,确保它们准确反映了代码的最新状态。

更新策略:

  • 建立代码审查机制,确保注释的更新。
  • 养成在修改代码的同时更新注释的习惯。
  • 使用版本控制系统来跟踪注释的变更历史。
  • 在代码提交信息中说明对注释的修改内容。

八、示例

对于一些复杂的概念或逻辑,提供简单的示例可以极大地增强注释的效果。例如,如果你在解释一个正则表达式的用法,可以给出几个匹配和不匹配的示例字符串。

假设我们有一个正则表达式用于验证电子邮件地址:

  import re
email_pattern = r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$"
def validate_email(email):
    """
    此函数使用正则表达式验证电子邮件地址的有效性
    参数:
    email (str) - 待验证的电子邮件地址
    示例:
    有效电子邮件: "test@example.com", "user123@gmail.com"
    无效电子邮件: "invalid_email", "no_domain@"
    """
    if re.match(email_pattern, email):
        return True
    else:
        return False
实践要点:
  • 确保示例具有代表性,涵盖各种可能的情况。
  • 对于示例中的关键部分,在注释中进行特别说明。

合理的注释是优质代码的重要标志之一。在日常编程中尝试遵循上述原则和方法,可以为写出清晰、有用的注释提供帮助,同时提高代码的质量和可维护性,为自己和其他开发者节省大量的时间和精力。

最后也希望大家永远不会碰见开头那样的代码注释~

点赞
收藏
评论区
推荐文章
笑出腹肌!程序员从不撒谎,但注释却会!
好买网(www.goodmai.com)IT技术交易平台所以,世上本没有注释,代码写多了,也便有了注释。1、这是一个被代码耽误的诗人2、来一份1987年的代码看看3、产品经理要对此负责4、不敢看,也不敢问5、Nike官网robots.txt上的注释6、程序员正确发牢骚的地方7、阅读源码的人,心里一定的崩溃的8、第一天上班看到这段注释就想辞职。9、我
Stella981 Stella981
3年前
Docker安装showdoc
一、简介ShowDoc是什么每当接手一个他人开发好的模块或者项目,看着那些没有写注释的代码,我们都无比抓狂。文档呢?!文档呢?!Showmethedoc!!程序员都很希望别人能写技术文档,而自己却很不希望要写文档。因为写文档需要花大量的时间去处理格式排版,想着新建的word文档放在哪个目录等各种
Wesley13 Wesley13
3年前
Vs code自动生成Doxygen格式注释
前言​程序中注释的规范和统一性的重要性不言而喻,本文就推荐一种在用vscode编写代码时自动化生成标准化注释格式的方法,关于Doxygen规范及其使用可查看博文代码注释规范之Doxygen(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.cnblogs.com%2F
Stella981 Stella981
3年前
HTML5+CSS+JS 贪吃蛇demo
我写博客的主要目的就是温习所学的知识,自己以前写的游戏当然不能放过!这款网页版贪吃蛇是大一下册学习网页前端时老师教我们写的,由于那个时候初学网页前端,所以这款游戏是纯原生JavaScript写的,没有使用JQuery。重新看了一遍自己写的代码,大一的我真的太年轻了,一个注释都没有写,幸好这款游戏的逻辑不难,还能看得懂,补了一些注释,对一些细节加深了
Wesley13 Wesley13
3年前
Java编程中必备的好习惯
最近在做应用的性能优化,在review代码的过程中积累了一些规则和经验。做到这些规则的目的很简单,就是写出“优美”的代码来。1、注释尽可能全面对于方法的注释应该包含详细的入参和结果说明,有异常抛出的情况也要详细叙述;类的注释应该包含类的功能说明、作者和修改者。!Java编程中写出好代码的建议(http://static.oschin
Wesley13 Wesley13
3年前
C++ 注释
C注释程序的注释是解释性语句,您可以在C代码中包含注释,这将提高源代码的可读性。所有的编程语言都允许某种形式的注释。C支持单行注释和多行注释。注释中的所有字符会被C编译器忽略。1include<iostream23/runthisprogramusingthe
Wesley13 Wesley13
3年前
OSEA中QRS波检测算法代码分析
最近一直在搞R波检测算法,对OSEA代码主要是对注释做一个翻译,增加注释,使代码更容易理解。一、首先看QRSDE.H/FILE:qrsdet.hAUTHOR:Pat
Wesley13 Wesley13
3年前
Apiggs
前言程序员一直以来都有一个烦恼,只想写代码,不想写文档。代码就表达了我的思想和灵魂。Python提出了一个方案,叫docstring,来试图解决这个问题。即编写代码,同时也能写出文档,保持代码和文档的一致。docstring说白了就是一堆代码中的注释。Python的docstring可以通过help函数直接输出一份有格式的文档,本工具
小万哥 小万哥
1年前
Python 注释:解释和优化代码可读性
注释可以用来解释Python代码。注释可以用来使代码更易读。注释可以用来在测试代码时防止执行。创建注释注释以开始,Python会忽略它们:示例:获取您自己的Python注释Python这是一个注释print("Hello,World!")注释可以放在一行的
小万哥 小万哥
1年前
C 语言注释和变量详解
C语言中的注释C语言中可以使用注释来解释代码并使其更具可读性。它还可以在测试替代代码时防止执行。单行注释单行注释以两个斜杠(//)开头。//和行末之间的任何文本都会被编译器忽略(不会被执行)。此示例在代码行之前使用单行注释:c//这是一个注释printf(