关于#ifndef,#define,#end的说明

#ifndef,#define,#end 是宏定义的一种---条件编译

这样我直接举个例子好了:
我定义两个相同的类A分别在single.h和singlenew.h 

single.h:

 1 #include <iostream>
 2 using namespace std;
 3
 4 class A
 5 {
 6 public:
 7     A()
 8     {
 9         cout<<"Single header Define"<<endl;
10     }
11 };

singlenew.h

 1 #include <iostream>
 2 using namespace std;
 3
 4 class A
 5 {
 6 public:
 7     A()
 8     {
 9         cout<<"SingleNew_h header Define"<<endl;
10     }
11 };

现在我们写个测试函数定义一个类A的实例,看它究竟会调用哪个:

main.cpp:

 1 #include "single.h"
 2 #include "singlenew.h"
 3 #include <iostream>
 4 using namespace std;
 5
 6
 7 int main()
 8 {
 9     A a;
10     return 0;
11 }

我们编译一下,咦,出错了:

意思是类A重定义了。

为什么呢:因为我们头文件中包含了single.h和singlenew.h 在这两个头文件中都定义了类A,那么久出现这个错误

现在我们重新给两个头文件加上条件编译:

single.h

 1 #ifndef _CLASS_A
 2 #define _CLASS_A
 3 #include <iostream>
 4 using namespace std;
 5
 6 class A
 7 {
 8 public:
 9     A()
10     {
11         cout<<"Single header Define"<<endl;
12     }
13 };
14 #endif

singlenew.h

 1 #ifndef _CLASS_A
 2 #define _CLASS_A
 3 #include <iostream>
 4 using namespace std;
 5
 6 class A
 7 {
 8 public:
 9     A()
10     {
11         cout<<"SingleNew_h header Define"<<endl;
12     }
13 };
14 #endif

main.c文件不变,现在我们重新编译运行。

这下正确了吧,当然我们还有个疑问,为什么执行了single.h中定义的类的构造函数。

这是因为在主函数中我们先包含"single.h"再包含"singlenew.h"的原因

当在single.h中找到了class A的定义,那么已经有了_CLASS_A这个宏定义了,再进入

"singlenew.h"文件中发现已经有了宏_CLASS_A的定义,于是直接略过该文件中的

类A的定义.

不信我们交换single.h和singlenew.h在主函数的位置:就有如下结果了。

这下对了吧。

当然也许你有疑问说不会有人傻到定义两个相同的类。其实条件编译宏定义多数函数用在解决

文件重复包含的情况下。比如类A定义在A.h中 我们在文件B中使用了类A,那么文件B必然要包含

A.h 这时如果有个C文件同时用到了类A和类B是不是要同时包含文件A和文件B呢,然而文件B中

已经包含了文件A,此时是不是文件C将包含文件A两次呢,所以条件编译大多数用在这种情况,

当我们的工程很庞大的时候,你会发现会经常出现重复包含相同文件的问题,所以条件编译在

大工程中被广泛应用。

时间: 2024-07-31 14:24:59

关于#ifndef,#define,#end的说明的相关文章

#ifndef #define #endif 防止头文件被重复引用

想必很多人都看过“头文件中的 #ifndef/#define/#endif 防止该头文件被重复引用”.但是是否能理解“被重复引用”是什么意思?是不能在不同的两个文件中使用include来包含这个头文件吗?如果头文件被重复引用了,会产生什么后果?是不是所有的头文件中都要加入#ifndef/#define/#endif 这些代码?   其实“被重复引用”是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的.比如:存在a.h文件#include "c.h

浅谈c/c++头文件中#ifndef/#define/#endif的用法

想必很多人都看过“头文件中用到的 #ifndef/#define/#endif 来防止该头文件被重复引用”.但是是否能理解“被重复引用”是什么意思?头文件被重复引用了,会产生什么后果?是不是所有的头文件中都要加入#ifndef/#define/#endif 这些代码? 1. 其实“被重复引用”是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的.如:存在a.h文件#include "c.h"而此时b.cpp文件导入了#include &q

ifndef /define/ endif 作用和用法

问题:ifndef/define/endif”主要目的是防止头文件的重复包含和编译========================================================用法: .h文件,如下:#ifndef XX_H#define XX_H...#endif 这样如果有两个地方都包含这个头文件,就不会出现两次包含的情况 ..因为在第二次包含时 XX_H 已经有定义了,所以就不再 include了--------------------------------------

#ifndef/#define/#endif使用(转载)

想必很多人都看过"头文件中的 #ifndef/#define/#endif 防止该头文件被重复引用".但是是否能理解"被重复引用"是什么意思?是不能在不同的两个文件中使用include来包含这个头文件吗?如果头文件被重复引用了,会产生什么后果?是不是所有的头文件中都要加入#ifndef/#define/#endif 这些代码? 其实"被重复引用"是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的.

【转】#ifndef/#define/#endif使用详解

转自:http://blog.csdn.net/abc5382334/article/details/18052757 想必很多人都看过“头文件中的 #ifndef/#define/#endif 防止该头文件被重复引用”.但是是否能理解“被重复引用”是什么意思?是不能在不同的两个文件中使用include来包含这个头文件吗?如果头文件被重复引用了,会产生什么后果?是不是所有的头文件中都要加入#ifndef/#define/#endif 这些代码? 其实“被重复引用”是指一个头文件在同一个cpp文件

C++头文件为什么要加#ifndef #define #endif

#ifndef 在头文件中的作用 在一个大的软件工程里面,可能会有多个文件同时包含一个头文件,当这些文件编译链接成一个可执行文件时 ,就会出现大量“重定义”的错误.在头文件中实用#ifndef #define #endif能避免头文件的重定义. 方法:例如要编写头文件test.h 在头文件开头写上两行: #ifndef _TEST_H #define _TEST_H                 //一般是文件名的大写 头文件结尾写上一行: #endif 这样一个工程文件里同时包含两个test

#ifndef #define

1 #ifndef __FIGHTING_H 2 #define __FIGHTING_H 3 4 // blahblah 5 6 #endif 这里#ifndef 和 #define 后面的字符串指宏定义,一般使用大写字母表示,可以是任意的字符串,一般为了方便理解尽量和头文件的名字保持一致,在头文件第一次被包含的时候该宏即被定义,编译器会给该字符串赋一个值,在下次引入头文件时就会发现该宏已经被定义,从而避免重复包含头文件.

#ifndef #define #endif 的用法

1.文件中的#ifndef 头件的中的#ifndef,这是一个很关键的东西.比如你有两个C文件,这两个C文件都include了同一个头文件.而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突. 还是把头文件的内容都放在#ifndef和#endif中吧.不管你的头文件会不会被多个文件引用,你都要加上这个.一般格式是这样的: #ifndef <标识> #define <标识> ...... ...... #endif <标识>在理论上来说可以是自

一个小程序猿思考之路-头文件中#ifndef/#define/#endif作用和用法

编写自定义头文件时,原来就是随意的编写一些内容,但是很少去想过头文件的格式: 突然一天,发现自己的头文件里有这么几个小东西 : #ifndef DAO_H#define DAO_H ... #endif 上面这个有什么详细的意义? 恍惚的记着是为了避免头文件多次调用,造成多次编译,引起重定义的错误: