0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言如何注释以及在哪儿注释

strongerHuang 来源:strongerHuang 作者:strongerHuang 2022-06-17 09:22 次阅读

如果领导给你一个项目的源码让你阅读,并理解重构代码,但里面一句注释都没有,我想这肯定是之前同事“删库跑路”了。 看一份源码什么很重要?除了各种代码规范之外,还有一个比较重要的就是注释。 注释虽然写起来很痛苦, 但对保证代码可读性至关重要,下面的将描述如何注释以及在哪儿注释。

注释风格

1.总述

一般使用///**/,只要统一就好。

2.说明

///**/都可以,但//常用,要在如何注释及注释风格上确保统一。

文件注释

1.总述在每一个文件开头加入版权、作者、时间等描述。 文件注释描述了该文件的内容,如果一个文件只声明,或实现,或测试了一个对象,并且这个对象已经在它的声明处进行了详细的注释,那么就没必要再加上文件注释,除此之外的其他文件都需要文件注释。 2.说明法律公告和作者信息每个文件都应该包含许可证引用. 为项目选择合适的许可证版本(比如, Apache 2.0, BSD, LGPL, GPL)。 如果你对原始作者的文件做了重大修改,请考虑删除原作者信息。 3.文件内容

如果一个.h文件声明了多个概念, 则文件注释应当对文件的内容做一个大致的说明, 同时说明各概念之间的联系. 一个一到两行的文件注释就足够了, 对于每个概念的详细文档应当放在各个概念中, 而不是文件注释中。

不要在.h.cc之间复制注释, 这样的注释偏离了注释的实际意义。

函数注释

1.总述函数声明处的注释描述函数功能; 定义处的注释描述函数实现。 2.说明函数声明:基本上每个函数声明处前都应当加上注释, 描述函数的功能和用途. 只有在函数的功能简单而明显时才能省略这些注释(例如, 简单的取值和设值函数)。 比如:FreeRTOS创建任务函数申明:

04658136-edda-11ec-ba43-dac502259ad0.png

函数定义:如果函数的实现过程中用到了很巧妙的方式, 那么在函数定义处应当加上解释性的注释。比如, 你所使用的编程技巧, 实现的大致步骤, 或解释如此实现的理由. 举个例子, 你可以说明为什么函数的前半部分要加锁而后半部分不需要。

不要.h文件或其他地方的函数声明处直接复制注释. 简要重述函数功能是可以的, 但注释重点要放在如何实现上。

变量注释

1.总述通常变量名本身足以很好说明变量用途, 某些情况下, 也需要额外的注释说明。

2.说明根据不同场景、不同修饰符,变量可以分为很多种类,总的来说变量分为全局变量、局部变量。 一般来说局部变量仅限于局部范围,其含义相对简单容易理解,只需要简单注释即可。 全局变量一般作用于多个文件,或者整个工程,因此,其含义相对更复杂,所以在注释的时候,最好描述清楚其具体含义,就是尽量全面描述。(提示:全局变量尽量少用)

拼音注释

1.总述可能一个变量、一个函数包含的意思非常复杂,需要多个单词拼写而成,此时对拼写内容就需要详细注释。

2.说明注释的通常写法是包含正确大小写和结尾句号的完整叙述性语句. 大多数情况下, 完整的句子比句子片段可读性更高. 短一点的注释, 比如代码行尾注释, 可以随意点, 但依然要注意风格的一致性。 同时,注释中的拼写、逗号也很重要。虽然被别人指出该用分号时却用了逗号多少有些尴尬, 但清晰易读的代码还是很重要的. 正确的标点, 拼写和语法对此会有很大帮助

TODO 注释

1.总述对那些临时的, 短期的解决方案, 或已经够好但仍不完美的代码使用TODO注释。TODO注释要使用全大写的字符串TODO, 在随后的圆括号里写上你的名字, 邮件地址, bug ID, 或其它身份标识和与这一TODO相关的 issue. 主要目的是让添加注释的人 (也是可以请求提供更多细节的人) 可根据规范的TODO格式进行查找. 添加TODO注释并不意味着你要自己来修正, 因此当你加上带有姓名的TODO时, 一般都是写上自己的名字。

最后

注释固然很重要, 但最好的代码应当本身就是文档,有意义的类型名和变量名, 要远胜过要用注释解释的含糊不清的名字。

你写的注释是给代码阅读者看的, 也就是下一个需要理解你代码的人. 所以慷慨些吧, 下一个读者可能就是你!

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • C语言
    +关注

    关注

    180

    文章

    7604

    浏览量

    136692
  • 代码
    +关注

    关注

    30

    文章

    4779

    浏览量

    68524

原文标题:C语言的注释要注意几点

文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    C语言关键字分别发生在哪个阶段

    以下C语言关键字,分别发生在哪个阶段? 第一个,define。 首先得纠正一下,define 并不是C语言里面的关键字,即使加了井号,也不是
    的头像 发表于 11-24 10:31 171次阅读

    PCM2707为什么无法被电脑识别?

    现在只焊接了最基础的部分,其它如控制跟I2S接口都还没连接元件,相当于空接,,现在无法被电脑识别,系统WI8-64BIT,我购买的PCM2704的板可以被电脑正常识别,请问下,问题出在哪儿
    发表于 11-06 06:25

    请问有没有单片机通过I2C配置AIC3204的相关例程,或者在哪儿可以找到?

    请问有没有单片机通过I2C配置AIC3204的相关例程,或者在哪儿可以找到?例如设置AIC3204的ADC等
    发表于 11-01 07:36

    C语言与Java语言的对比

    C语言和Java语言都是当前编程领域中的重要成员,它们各自具有独特的优势和特点,适用于不同的应用场景。以下将从语法特性、内存管理、跨平台性、性能、应用领域等多个方面对C
    的头像 发表于 10-29 17:31 316次阅读

    新能源机车电传动系统“新”在哪儿

    中国中车面向全球首次发布系列化新能源机车,7款代表车型集中亮相。中车永济电机公司为系列化新能源机车研制开发了电传动系统解决方案,包括牵引辅助变流系统、牵引电机、网络控制系统等核心部件。
    的头像 发表于 09-14 10:57 474次阅读

    TLV2252A运放产生了低频振荡是哪里出了问题?

    如图所示,本人用作一个红外传感器的驱动,但是运放输出莫名的振荡了,请帮忙看看原因是什么了? 输出振荡信号为参考电压(225mv)到轨电压(3V3)的一个低频振荡(2.46HZ)。 请大拿们帮忙看看问题出在哪儿了?
    发表于 07-31 06:52

    esp8266向http server发送post请求,发送一段时间之后会返回ESPCONN_MEM,为什么?

    callback,然后再发下一包,我不知道tcp_pcb是在哪儿close和删除的,我尝试在disconnect callback和reconnect callback中调用espconn_delete或
    发表于 07-10 08:13

    ESP-ADF例程编译过程出错,提示找不到“esp_afe_sr_iface.h”文件,为什么?

    ESP-ADF例程编译过程出错,提示找不到“esp_afe_sr_iface.h”文件,在github和gitee仓库上找遍了也没有这个文件,请问有大神知道在哪儿有吗?
    发表于 06-17 08:03

    在哪儿可以修改DAC口的输出变量?

    大家好,就是workbench生成程序的时候,会在DAC那里选择通道的输出信息。然后脱离Workbench想在程序里直接修改的时候在dac_ui.c里往下找的时候,找到了在user_interface.h里边有很多这个定义,但就是没明白在哪儿可以修改DAC口的输出变量。所
    发表于 04-02 06:45

    labview时频域分析

    各位,问一下我的这个幅值频谱图的幅值为什么和时域不匹配,请问问题出在哪儿?感谢!!!
    发表于 03-30 15:56

    NUCLEO-G474RE开发板的例程在哪儿下载?如和用usb和pc串口通信?

    NUCLEO-G474RE这个开发板的例程在哪儿下载啊,不知道如和用他的usb和pc串口通信
    发表于 03-18 08:22

    为什么你会觉得vim非常难用?因为你的配置不对

    文件中,需要注意的是,他的语法规则跟C语言不一样,比如注释用的是双引号。常用的几个配置如下。
    的头像 发表于 03-04 10:31 827次阅读

    c语言,c++,java,python区别

    操作系统、嵌入式系统等对性能要求较高的场景。C语言的语法相对简单,学习曲线较平缓,也是学习其他高级语言的入门语言C++:
    的头像 发表于 02-05 14:11 2365次阅读

    IGBT芯片主要用在哪儿

    如今全球的汽车已经进入到智能化时代,汽车对于芯片的需求剧烈增加,以往一个传统汽车需要的芯片数量是在五六百颗,到如今一台具备L2驾驶级别的高配燃油车就需要1000颗以上的芯片,一个配置较好的新能源纯电汽车更是需要2000颗以上芯片。而在众多新能源汽车芯片中,IGBT芯片绝对称得上“皇冠上的宝石”。
    的头像 发表于 01-03 09:43 1151次阅读
    IGBT芯片主要用<b class='flag-5'>在哪儿</b>

    ADE7878相位差别较大超出可校准的范围是什么原因造成的?

    在用ADE7878进行校准时,发现三相电压和电流之间的相角差大概为84度,远远超出了相位校准寄存器可校准的范围。电压信号调理电路用的是几个电阻分压(未使用互感器)、电流调理电路用的是互感器将大电流转化为小电流,如下图所示, 请各位指教,可能出现的问题在哪儿
    发表于 12-26 07:29