C语言中注释与注意事项的深入讲解

 更新时间:2021年09月01日 11:35:35   作者:精致的灰(>_<)  
在编写C语言源代码时,应该多使用注释,这样有助于对代码的理解,这篇文章主要给大家介绍了关于C语言中注释与注意事项的相关资料,需要的朋友可以参考下

C语言注释简介:

注释应该出现在三种位置

  • 文件头部
  • 函数头部
  • 函数体内的和代码混在一起的注释

对于文件头部的注释至少列出:

  • 版权声明、版本号、文件创建日期、作者、内容/功能、与其他文件的关系、修改日志等。

函数头部注释要求至少列出:

  • 函数功能、输入/输出参数、返回值、调用/被调用关系等。

C语言注释实例

注释在预编译阶段就会被删除掉,但是这里的删除并不是字面意义的删除,而是被替换,注释被替换,本质是替换成空格。

以下面的代码为例:

#include <stdio.h> 
int main() 
{ 
int /* */ i; //正确 
char *s = "abcdefgh   //hijklmn"; //正确 
//Is it a\
  valid comment? //正确 
in/* */t j; //报错 
return 0; 
}

由于被替换成了空格,所以in t j这句话是无法编译的。

如果是C语言风格的注释出现了嵌套,则/*总是与离它最近的*/匹配,第二个/*并不会被认为是注释符号,因此第一个/*与第一个*/匹配,代码会剩下一个*/:

注释的一些注意事项

  1. 注释应当准确、易懂,反之有二义性。错误的注释容易产生误导,不利于代码维护。
  2. 边写代码边修改注释,修改代码的同时要修改对应的注释,保证注释和代码的一致性。不再有用的注释要及时删除。
  3. 注释是对代码的“提示”,所以注释应当简单明了,因为注释太多会让人眼花缭乱。
  4. 对于全局数据(全局变量、常量定义等)必须要加注释。注释清楚定义全局数据的目的。
  5. 注释的位置应该与被描述的代码相邻,可以与语句在同一行,也可以在语句的上一行,但不能在语句的下一行,因为这样不符合人的阅读习惯。
  6. 当代码比较长,特别是有多重嵌套时,应当在一些段落结束时加注释,便于阅读。
  7. 注释的缩进要与代码的缩进一致,这样代码会更美观,可读性强。
  8. 注释代码段时应当注重“为何做”而不是“怎么做”,要说明这段代码的操作意图。
  9. 数值的单位一定要注释。
  10. 对变量的范围给出注释,特别是参数。
  11. 对一系列的数字编号给出注释,尤其是在编写底层驱动的程序。
  12. 避免在一行代码或表达式的中间插入注释。
  13. 复杂的函数中,在分支语句、循环语句结束之后需要加注释,方便区分各分支或循环体。

总结

到此这篇关于C语言中注释与注意事项的文章就介绍到这了,更多相关C语言注释与注意事项内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈C#中List<T>对象的深度拷贝问题

    浅谈C#中List<T>对象的深度拷贝问题

    下面小编就为大家带来一篇浅谈C#中List<T>对象的深度拷贝问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • Qt自制一个小闹钟的实现示例

    Qt自制一个小闹钟的实现示例

    本文主要介绍了Qt自制一个小闹钟的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-09-09
  • Qt采用线程以队列方式实现下发数据

    Qt采用线程以队列方式实现下发数据

    在C++中队列是一种常用的数据结构之一,一种特殊的线性表,一般采用先进先出的方式。本文主要为大家介绍了Qt如何以队列方式实现下发数据,感兴趣的可以了解一下
    2022-10-10
  • 简单分析C语言中指针数组与数组指针的区别

    简单分析C语言中指针数组与数组指针的区别

    这篇文章主要介绍了C语言中指针数组与数组指针的区别,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • C++ API功能设计的实现

    C++ API功能设计的实现

    C++ API中看似很小的修改,都可能会影响到生成的对象和库文件的二进制表示,如果客户想替换共享库使之工作,就不能简单的替换库文件了事,而往往需要重新编译
    2022-08-08
  • C语言用栈实现十进制转换为二进制的方法示例

    C语言用栈实现十进制转换为二进制的方法示例

    这篇文章主要介绍了C语言用栈实现十进制转换为二进制的方法,结合实例形式分析了C语言栈的定义及进制转换使用技巧,需要的朋友可以参考下
    2017-06-06
  • C++17之std::any的具体使用

    C++17之std::any的具体使用

    本文主要介绍了C++17之std::any的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Qt如何设置窗口屏幕居中显示以及设置大小

    Qt如何设置窗口屏幕居中显示以及设置大小

    这篇文章主要介绍了Qt如何设置窗口屏幕居中显示以及设置大小的相关资料,需要的朋友可以参考下
    2017-01-01
  • 详析C++中的auto

    详析C++中的auto

    这篇文章主要介绍了详析C++中的auto,auto是具有自动存储器的局部变量,C++11中,标准委员会赋予了auto全新的含义即:auto不再是一个存储类型指示符,而作为一个新的类型指示符来指示编译器,下面来看看文章的详细介绍吧
    2022-01-01
  • C语言中fgets和fscanf区别详解

    C语言中fgets和fscanf区别详解

    这篇文章主要介绍了C语言中fgets和fscanf区别详解的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下
    2017-10-10

最新评论