- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章浅谈#ifndef,#define,#endif的作用和用法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
问题:ifndef/define/endif”主要目的是防止头文件的重复包含和编译 。
======================================================== 。
用法:
.h文件,如下: #ifndef XX_H #define XX_H ... #endif 。
这样如果有两个地方都包含这个头文件,就不会出现两次包含的情况 。.
因为在第二次包含时 XX_H 已经有定义了,所以就不再 include了 ------------------------------------------------------- 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#ifndef GRAPHICS_H // 防止graphics.h被重复引用
#define GRAPHICS_H
#include <
math.h
> // 引用标准库的头文件
…
#include “myheader.h” // 引用非标准库的头文件
…
void Function1(…); // 全局函数声明
…
class Box // 类结构声明
{
…
};
#endif
|
----------------------------------------------------- 。
那是指你建立多个文件时,多个文件里都包含这个头文件 ----------------------------------------------------- 。
给你举个例子,再顺便分析一下:
假设你的工程里面有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,就可以防止这种重定义错误。 -------------------------------------------------- ------------------------------------------------- 。
1.比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。 还是把头文件的内容都放在#ifndef和#endif中吧.
不管你的头文件会不会被多个文件引用,你都要加上这个.
一般格式是这样的:
#ifndef <标识> #define <标识> ...... ...... #endif <标识> 。
在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h 。
1
2
3
4
|
#ifndef _STDIO_H_
#define _STDIO_H_
......
#endif
|
2.在#ifndef中定义变量出现的问题(一般不定义在#ifndef中).
#ifndef AAA #define AAA ... int i; ... #endif 。
里面有一个变量定义在vc中链接时就出现了i重复定义的错误,而在c中成功编译.
原因:
(1).当你第一个使用这个头的.cpp文件生成.obj的时候,int i 在里面定义了当另外一个使用这个的.cpp再次[单独]生成.obj的时候,int i 又被定义然后两个obj被另外一个.cpp也include 这个头的,连接在一起,就会出现重复定义. 。
(2).把源程序文件扩展名改成.c后,VC按照C语言的语法对源程序进行编译,而不是C++。在C语言中,若是遇到多个int i,则自动认为其中一个是定义,其他的是声明.
(3).C语言和C++语言连接结果不同,可能(猜测)在进行编译的时候,C++语言将全局变量默认为强符号,所以连接出错。C语言则依照是否初始化进行强弱的判断的.
参考解决方法:
(1).把源程序文件扩展名改成.c.
(2).推荐解决方案: .h中只声明 extern int i,
在.cpp中定义 。
#ifndef __X_H__ #define __X_H__ extern int i; #endif //__X_H__ int i; 注意问题:变量一般不要定义在.h文件中.
以上就是小编为大家带来的浅谈#ifndef,#define,#endif的作用和用法全部内容了,希望大家多多支持我~ 。
最后此篇关于浅谈#ifndef,#define,#endif的作用和用法的文章就讲到这里了,如果你想了解更多关于浅谈#ifndef,#define,#endif的作用和用法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这个问题在这里已经有了答案: Boolean in ifdef: is "#ifdef A && B" the same as "#if defined(A) && defined(B)"? (5
考虑代码。 #ifndef FOO_H #define FOO_H //Code #endif 代码可以是以下情况 // Case 1: #define foo 0 // Case 2: void f
我试图弄清楚如何将 C 头文件与 #ifndef 和 #include 一起使用。假设我有这两个头文件: headerA.h: #ifndef HEADERA_H #define HEADERA_H
假设我有a.h其中包括以下内容: 假设我还有b.h其中还包括 。如果a.h有#ifndef其中的预处理器定义语句和 b.h没有。会a.h仅包含 b.h 中未包含的内容?那么当 b.h包括a.h
我只是在定义常量时考虑以下方法之间的区别: 方法1:使用 include Guard 创建一个头文件来定义所有常量: #ifndef c1 #define c1 @"a123456789" #endi
所以我试图将我在 main.cpp 中声明的库包含到我的 header.h 中 //In my main.cpp #include #include #include using namespa
这个问题在这里已经有了答案: Header guard / translation unit problem (2 个答案) 关闭 9 年前。 有个问题让我百思不得其解。我知道这样做是不对的,但我不
类声明通常是这样的: #ifndef MY_CLASS_20141116 #define MY_CLASS_20141116 ... class MyClass { ... } #endif
我在 ifndef 中有一个结构,它在 visual studio 中是灰色的。它位于一个头文件中,然后包含在另一个 cpp 文件中。 cpp文件无法访问struct,导致编译错误。 我已经在 vis
Include guards在头文件中通常用于保护代码部分免受双重包含: #ifndef FOOBAR_H #define FOOBAR_H extern void myfoofunc(void);
我正在学习 C,希望有人能解释一下使用 #ifndef 的逻辑是什么? 我还发现我看过很多 C 程序,人们似乎遵循使用 #ifndef、#define 和 #endif 之后的文件名的约定>。取这个名
我正在尝试使用 #ifndef,如下所示。 #ifndef MACRO1 || #ifndef MACRO2 .... #endif 我已经试过了: #ifndef (MACRO1 || MACRO2
如果每个 header 都使用 #ifndef,这是否意味着关于循环依赖的编译器错误不会发生? 最佳答案 不,它没有。 这意味着编译器不会尝试包含无穷大的 header ,但是循环依赖仍然会带来逻辑问
为 PAL.h 中的函数指针获取“已在 GUI.obj 中定义”的 LNK2005 //GUI.cpp #include "PAL.h" //PAL.h #define PAL_INCLUDE int
请相信我:我搜索和测试了很多...但我没有弄错这里: VERSION := 123 all: ifndef VERSION $(error VERSION not set)
这个问题可能很奇怪,我目前正在研究一些旧代码(不是我写的)。我实际上不是 C 程序员,但我想了解这部分代码实际上应该做什么。幸运的是,奇怪的部分并不太长(配置的一部分): int main () {
我有一个使用Boost库的Qt / C++项目,并且看到Boost header 包含如下内容: #ifndef Q_MOC_RUN #include #include #endif 我读到,如果
我的 program.wxs 文件中有以下片段: ... ... 我正在使用以下
这个问题可能很奇怪,我目前正在研究一些旧代码(不是我写的)。我实际上不是 C 程序员,但我想了解这部分代码实际上应该做什么。幸运的是,奇怪的部分并不太长(配置的一部分): int main () {
这个问题在这里已经有了答案: Why aren't my include guards preventing recursive inclusion and multiple symbol defi
我是一名优秀的程序员,十分优秀!