c语言ifndef
❶ 关于c语言中的#ifndef。。。endif 的用法,求高手详解
#ifndef假如没有定义,那么进行宏定义。
#endif结束宏定义。
这个是为了避免头文件重复包含而定义的,一般这个宏的定义方式为__头文件名__H_
比方说你#include进来一个stdio.h,再#include进来一个string.h。也许在string.h头文件里又include了stdio.h。这样你的程序中就include了两个stdio.h。定义了两个printf函数等等。
这就麻烦了,编译会出错不说,就算编译过了也是浪费资源
加了一个#ifndef
_STDIO_H的话。在#include进来的string.h中如果再试图include一遍stdio.h的话,由于事先在第一个stdio.h中已经定义了_STDIO_H这个宏。所以不满足#ifndef
_STDIO_H这个条件,就不会编译第二次了。
#define
后面不一定要加两个字符串。一个也行,加一个字符串如#define
_STDIO_H
,
#define
DEBUG
等等,一般在编译前用来做开关。控制编译部分。上面所说的头文件中是一个例子。再举一个查错的例子
#define
DEBUG
...
...
#ifdef
DEBUG
fprintf(
stderr
,
"Debug
Message\n
"
);
#endif
...
当你程序完成之后。可以把#define
DEBUG一行用注释屏蔽掉。这样在编译的时候就不会把debug部分也编译进去了。
❷ C语言有个IFNDEF开始用来做
定义FLAG为1
所以 #ifndef不会被执行, 而是编译#else部分
即#define M 3
于是 输出为
2*M+6
注意 字符串中的M不会被替换。
❸ #ifndef的用法
#ifndef是宏定义里面的一种,用来防止防止头文件的重复包含和编译。
比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。
如果把头文件的内容都放在#ifndef和#endif中,不管你的头文件会不会被多个文件引用,你都要加上这个,就可以避免冲突的问题。
#ifndef可以根据是否已经定义了一个变量来进行分支选择,一般用于调试等等.实际上确切的说这应该是预处理功能中三种(宏定义,文件包含和条件编译)中的一种——条件编译。 C语言在对程序进行编译时,会先根据预处理命令进行“预处理”。C语言编译系统包括预处理,编译和链接等部分。
(3)c语言ifndef扩展阅读:
#ifndef一般格式是这样的:
#ifndef <标识>
#define <标识>
......
#endif
<标识>在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h
#ifndef _STDIO_H_
#define _STDIO_H_
......
#endif
❹ C语言 ifndef什么意思(作用)#define STR_LEN 30 什么意思
#ifndef x 意思就是如果x没有定义,则执行#endif之前的程序,如果定义就跳过。
#define STR_LEN 30 就是宏定义,程序中只要出现 STR_LEN 就用30代替,使程序直观
❺ C++#ifndef与#ifdef的区别是什么
一、使用场景不同:
#ifndef使用场景为:
1、头文件中使用,防止头文件被多重调用。
2、作为测试使用,省去注释代码的麻烦。
3、作为不同角色或者场景的判断使用。
#ifdef使用场景:
判断某个宏是否被定义,若已定义,执行随后的语句。
二、含义不同:
#ifndef表示ifnotdefine。
#ifdef表示ifdefine。
(5)c语言ifndef扩展阅读:
#ifndef起到的效果是防止一个源文件两次包含同一个头文件,而不是防止两个源文件包含同一个头文件。
而编译时,这两个C文件要一同编译成一个可运行文件。
把头文件的内容都放在#ifndef和#endif中。不管头文件会不会被多个文件引用,都要加上这个。
一般格式是这样的:
#ifndef <标识>
#define <标识>.
...........
#endif<标识>
在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。
标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:
#ifndef_STDIO_H_#define_STDIO_H_......#endif.
在#ifndef中定义变量出现的问题(一般不定义在#ifndef中)。
#ifndefAAA#defineAAA...inti;...#endif
❻ #ifndef的用法
文件中的#ifndef
头件的中的#ifndef,这是一个很关键的东西。比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。
还是把头文件的内容都放在#ifndef和#endif中吧。不管你的头文件会不会被多个文件引用,你都要加上这个。一般格式是这样的:
#ifndef
<标识>
#define
<标识>
......
......
#endif
<标识>在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h
#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中定义
<x.h>
#ifndef
__X_H__
#define
__X_H__
extern
int
i;
#endif
//__X_H__
<x.c>
int
i;
注意问题:
变量一般不要定义在.h文件中。
❼ c语言中的#ifndef,def,endif等宏是什么意思
这些是条件编译。
#ifdef 当后续宏被定义时,代码段会被编译。
#ifndef 当宏未定义时编译。
#endif 条件编译的结束标记。