#ifndef, #define, #endif作用

条件指示符#ifndef 的最主要目的是防止头文件的重复包含和编译

参考以下两个链接:

其实“被重复引用”是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的。比如:存在a.h文件#include "c.h"而此时b.cpp文件导入了#include "a.h"#include "c.h"此时就会造成c.h重复引用。


几个重要的问题:

  • #ifndef后面内容有什么要求吗?

其实在#ifndef后面加什么都都可以,只要保证其唯一性就可以了,用文件名只是为了好区分。它只是用来定义一个预处理器变量。


  • 如果出现两个头文件#ifndef后面的内容相同怎么办?

通过“#ifndef/#define/#endif”结构产生预处理块,虽然能够避免同一个头文件被多次包含和重复引用,但也存在一个致命的缺点,那就是一旦一不小心在不同头文件中定义了相同的宏名,问题就比较麻烦了。比如,可能会导致明明看到存在头文件,而编译器却硬说找不到声明等问题。为了避免这种情况,保证宏名的唯一性,建议按照 Google 公司的建议,头文件基于其所在项目源代码树的全路径进行命名。命名格式为:
<PROJECT>_<PATH>_<FILE>_H_
其中,PROJECT 表示项目名称,PATH 表示头文件相对路径,FILE 表示文件名,再以“H”作为后缀。比如,在项目 CashRegister 中,现在该项目所在目录下的一个名为 xml 的子文件夹下的一个 parser 头文件,则宏定义如下:

#ifndef CASHREGISTER_XML_PARSER_H_
#define CASHREGISTER_XML_PARSER_H_
/*声明、定义语句*/
#endif

参考自条件编译指令(符号),C语言条件编译指令完全攻略


  • 是不是所有的头文件中都要加入#ifndef, #define, #endif这些代码?

不是一定要加,但是不管怎样,用#ifnde xxx #define xxx #endif或者其他方式避免头文件重复包含,只有好处没有坏处。个人觉得培养一个好的编程习惯是学习编程的一个重要分支。


  • 为什么#ifndef后面的内容都是大写?

因为#ifndef本质上是一种宏定义,习惯大写。


  • 有时可以写成#ifndef _HEADER_H_,下划线怎么理解?

下划线“__”属于编程风格的内容,对程序没有影响。不用下划线也可以,用几个下划线也由个人习惯;甚至可以写成#ifndef HEADER.H,因为#ifndef 后面的字符串,不管是HEADER.H还是__HEADER_H和头文件的名字没有半毛钱关系。只不过是为了读程序的时候方便而已。其实那个字符串只要合法的就行了
Note: ___开头的函数一般都是专用的函数,一般都是于特定系统相关的,如果要想有更好的移植性,应该避免使用。一般只有已经广泛使用的系统库函数和宏才有资格使用_甚至__打头,为的是不与用户定义的名字冲突,所以B.Stroustup在《The C++ Programming Language》中告诫我们一般不要使用_或__打头的标志符,这也是一个编程风格的问题吧。

猜你喜欢

转载自blog.csdn.net/lyh458/article/details/114992623