头文件中的ifndef/define/endif是干什么用的?

例如:要编写头文件test.h

         在头文件开头写上两行:

          #ifndef _TEST_H

          #define _TEST_H//一般是文件名的大写

         ············

         ············

         头文件结尾写上一行:

          #endif

    大概是以前没有学好吧,对这里不是很理解,为什么要用这些呢?刚才上网查了查,借鉴了点高手的,自己总结了一点,就写在这里了,有什么错误之处,请大侠们指出

    1.比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。

例如:

假设你的工程里面有4个文件,分别是a.cpp,b.h,c.h,d.h。 
a.cpp的头部是: 
#include   "b.h " 
#include   "c.h " 
b.h和c.h的头部都是: 
#include   "d.h " 
而d.h里面有class   D的定义。 
这样一来, 
编译器编译a.cpp的时候,先根据#include   "b.h "去编译b.h这个问题,再根据b.h里面的#include   "d.h ",去编译d.h的这个文件,这样就把d.h里面的class   D编译了; 
然后再根据a.cpp的第二句#include   "c.h ",去编译c.h,最终还是会找到的d.h里面的class   D,但是class   D之前已经编译过了,所以就会报重定义错误。 加上ifndef/define/endif,就可以防止这种重定义错误。

所以还是把头文件的内容都放在#ifndef和#endif中吧。 
不管你的头文件会不会被多个文件引用,你都要加上这个。 
一般格式是这样的:   
#ifndef   <标识 >   
#define   <标识 >   
......   
......   
#endif   <标识 > 
在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h   
#ifndef   _STDIO_H_   
#define   _STDIO_H_   
......   
#endif  

猜你喜欢

转载自my.oschina.net/feistel/blog/1626136