例如:要编写头文件test.h编译器
在头文件开头写上两行:io
#ifndef _TEST_H编译
#define _TEST_H//通常是文件名的大写class
············test
············引用
头文件结尾写上一行:总结
#endif命名
大概是之前没有学好吧,对这里不是很理解,为何要用这些呢?刚才上网查了查,借鉴了点高手的,本身总结了一点,就写在这里了,有什么错误之处,请大侠们指出di
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