条件编译#ifndef和#endif

1 条件编译

一般情况下,源程序中所有的行都参加编译。但是有时希望对其中一部分内容只在满足一定条件才进行编译,也就是对一部分内容指定编译的条件,这就是“条件编译”。有时,希望当满足某条件时对一组语句进行编译,而当条件不满足时则编译另一组语句。

2 条件编译命令最常见的形式

#ifndef 标识符
程序段1
#else
程序段2
#endif
**作用:**当标识符已经被定义过(一般是用#define命令定义),则对程序段1进行编译,否则编译程序段2。
其中#else部分也可以没有,即:
#ifndef
程序段1
#denif

3 例子

在头文件中使用#ifndef和#endif是非常重要的,可以防止双重定义的错误。
例如:在头文件aaa.h中定义了一个类aaa如下:
class aaa
{
};
如果两次#include “aaa.h”(不见得是直接,也有可能两个不同的头文件中都包含了这个头文件)就会出错,因为相同的类不能定义两次。把aaa.h稍做修改:
#ifndef aaa
#define aaa
class aaa
{
};
#endif
就可以避免这样的问题。
因为当你已经包含过这个文件,_aaa_就会有了定义,那么#ifndef的条件为假,就不会再执行后面的类定义了。

4 书写规则

把头文件的内容都放在#ifndef和#endif中。不管你的头文件会不会被多个文件引用,你都要加上这个。一般格式是这样的:
#ifndef 标识
#define 标识


#endif

<标识>在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h

#ifndef STDIO_H
#define STDIO_H

#endif

4 其他事项

(1)#ifdef和#endif必须成对使用。
(2)从理论上讲可以出现在任何地方(头文件和实现文件中)
(3)通常为了防止头文件被多次包含,在头文件中使用是必须的

转载至:https://www.cnblogs.com/mmziscoming/p/4875276.html

5. ifdef _ DEBUG_

在#ifdefine _DEBUG和对应的#endif中有代码,则这些代码只有在调试(debug)下才会被编译。也就是说,如果你在release模式下,这些代码根本不会存在于你的最终代码里头。

你可能感兴趣的:(条件编译#ifndef和#endif)