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语言
    +关注

    关注

    183

    文章

    7648

    浏览量

    146230
  • 代码
    +关注

    关注

    30

    文章

    4978

    浏览量

    74445

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    工业以太网交换机适用于哪些场景?

    工业以太网交换机,真不是普通交换机的“加强版”那么简单。它能抗干扰、耐极端环境,是工业场景网络稳定的“定海神针”。广州邮科深耕工业通信领域多年,今天就用大白话聊聊,这铁疙瘩到底该用在哪儿,怎么选不踩坑。
    的头像 发表于 03-31 17:28 471次阅读
    工业以太网交换机适用于哪些场景?

    C语言安全编码指南:MISRA C、CERT C、CWE 与 C Secure 标准对比与Perforce QAC应用详解

    如何编写真正安全的C语言代码?指南涵盖MISRA C、CERT、CWE等国际安全编码标准对比,以及如何借助Perforce QAC自动检测漏洞。推荐给嵌入式/汽车/工业软件的开发者!
    的头像 发表于 01-26 17:38 1160次阅读
    <b class='flag-5'>C</b><b class='flag-5'>语言</b>安全编码指南:MISRA <b class='flag-5'>C</b>、CERT <b class='flag-5'>C</b>、CWE 与 <b class='flag-5'>C</b> Secure 标准对比与Perforce QAC应用详解

    汽车网络安全开发语言选型指南:C/C++/Rust/Java等主流语言对比+Perforce QAC/Klocwork工具支持

    汽车网络安全如何选编程语言CC++、Rust、Java……谁更适合AUTOSAR、ISO/SAE 21434?一文了解8种主流语言的优劣与适用场景,
    的头像 发表于 12-26 11:13 683次阅读
    汽车网络安全开发<b class='flag-5'>语言</b>选型指南:<b class='flag-5'>C</b>/<b class='flag-5'>C</b>++/Rust/Java等主流<b class='flag-5'>语言</b>对比+Perforce QAC/Klocwork工具支持

    电流互感器:那个天天帮你“盯着电流”的小玩意儿

    电流互感器,听名字挺“正经”的,但你知道吗?它其实是电子工程师的“电流观察员”、设备的“安全保镖”、企业的“省钱小帮手”。下面用轻松一点的方式,带你看看它都在哪儿“打工”。
    的头像 发表于 12-25 16:46 880次阅读
    电流互感器:那个天天帮你“盯着电流”的小玩意儿

    在ADS编译器中,用标准的C库函数printf()需要哪些设置呢?

    在ADS编译器中,用标准的C库函数printf()需要哪些设置呢?又在哪儿可以看到printf()输出的信息呢?
    发表于 12-23 07:32

    单片机C语言的误区介绍

    经常见网友们说,代码不能写太多了包括注释,单片机的ROM只有几个K的空间,其实这是表面问题的误解。 1、注释是写不进去hex文件的,下载到芯片里的只有你的有效代码汇编以后生成的机器码,注释自动编译器
    发表于 12-22 12:45

    C语言C++之间的区别是什么

    (STL),包含多种容器(如vector、list、map等)、算法以及迭代器,极大地提高了开发效率和代码复用性。 而C语言的标准库相对较小,虽然也提供了基本的数据结构(如数组、链表等)和算法的支持,但不
    发表于 12-11 06:23

    请问支持小数波特率接收数据的意义在哪儿

    我看芯源支持小数波特率,话说,支持小数波特率接收数据的意义在哪儿?是通讯更有精度吗?
    发表于 12-02 07:17

    C语言和单片机C语言有什么差异

    单片机c语言相对于普通C语言增加了一些基本的指令,还有变量的赋值是16进制,当然单片机c语言只牵
    发表于 11-14 07:55

    C语言的printf基本用法介绍

    个小数。f 是 float 的简写。 除了这些,printf 支持更加复杂和优美的输出格式,考虑到读者的基础暂时不够,我们将在《C语言数据输出大汇总以及轻量进阶》一节中展开讲解。 我们把代码补充完整
    发表于 11-12 07:04

    第4章 C语言基础以及流水灯的实现(4.5 4.6)

    4.5while循环语句 在单片机C语言编程的时候,每个程序都会固定的加一句while(1),这条语句就可以起到死循环的作用。对于while语句来说,他的一般形式是:        while
    的头像 发表于 11-06 11:21 555次阅读

    第4章 C语言基础以及流水灯的实现(4.3 4.4)

    4.3 C语言基本运算符 小学数学学过加、减、乘、除等运算符号以及四则混合运算,而这些运算符号在C语言中也有,但是有些表达方法不一样,并且还
    的头像 发表于 10-29 15:30 449次阅读

    通信电源选购避坑指南:跟着广州邮科选,省心又省钱!

    “通信电源选不好,基站半夜闹罢工!”老李是某通信公司的运维主管,去年因贪便宜买了杂牌电源,结果夏天高温时连续3天基站宕机,客户投诉电话被打爆,差点丢了饭碗。后来换了广州邮科的电源,用了快两年,一次故障都没出过。今天咱们就聊聊通信电源选购的门道,顺便看看广州邮科到底牛在哪儿
    的头像 发表于 10-20 10:32 594次阅读
    通信电源选购避坑指南:跟着广州邮科选,省心又省钱!

    C语言精彩编程百例-364页

    内容提要 C是一种通用的程序设计语言,它包含了紧凑的表达式、丰富的运算符集合、现代控制流以及数据结构等四个部分。C语言功能丰富,衣达能力强,
    发表于 06-13 17:28

    《ESP32S3 Arduino开发指南》第三章 C/C++语言基础

    ++基础,由于篇幅有限,在此仅对C/C++语言基础进行简单介绍。本章将分为如下9个小节:3.1 数据类型3.2 运算符3.3 表达式3.4 数组3.5 字符串3.6 注释3.7 顺序结
    发表于 06-10 09:20