`
yxwang0615
  • 浏览: 549576 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

预处理命令——条件编译

阅读更多
   灵活使用#ifdef指示符,我们可以区隔一些与特定头文件、程序库和其他文件版本有关的代码,相当于一个开关,用#define定义,存在则执行#ifdef #endif块中的内容。
#include "iostream.h"
int main()
{
#ifdef DEBUG      
cout<< "Beginning execution of main()";//使用标准的输出流来做控制台的输出
#endif      
return 0;
}

运行结果为:Press any key to continue

改写代码如下:
#include "iostream.h"
#define DEBUG
int main()
{
#ifdef DEBUG      
cout<< "Beginning execution of main()";
#endif       
return 0;
}

运行结果为:Beginning execution of main()
                  Press any key to continue

更一般的情况是,#define语句是包含在一个特定的头文件中。
比如,新建头文件head.h,在文件中加入代码:
#ifndef DEBUG
#define DEBUG
#endif

代码修改如下:
#include "iostream.h"
#include "head.h" 
int main(){
#ifdef DEBUG      
cout<< "Beginning execution of main()";
#endif       
return 0;
}


运行结果如下:Beginning execution of main()
                    Press any key to continue

结论:通过使用#ifdef指示符,我们可以区分一些与特定头文件、程序库和其他文件版本有关的代码。

   预处理就是在进行编译的第一遍词法扫描和语法分析之前所作的工作。就是对源文件进行编译前,先对预处理部分进行处理,然后对处理后的代码进行编译。这样做的好处是,经过处理后的代码,将会变的很精短。
凡事以#开头的code均为预处理命令,define为宏定义命令
#define 标识符 字符串  eg:
#define CM_COMMAND_NOTE 0x000U
程序中遇到CM_COMMAND_NOTE 的地方都会由0x000U代替


条件编译的几种情况:
情况一:
#ifdef _XXX
...程序段1...
#else
...程序段2...
#endif
   这表明如果标识符XXX已被#define命令定义过,则对程序段1进行编译;否则对程序段2进行编译。

情况二:
#ifndef _XXXX
...程序段1...
#else
...程序段2...
#endif
   如果没有定义标识符XXXX,那么执行程序段1,否则执行程序段2。

情况三:
#if 常量
...程序段1...
#else
...程序段2...
#endif
   这里表示,如果常量为真(非0,随便什么数字,只要不是0),就执行程序段1,否则执行程序段2。
   这种方法可以将测试代码加进来。当需要开启测试的时候,只要将常量变1,而不要测试的时候,只要将常量变0。

情况四:
头文件中的#ifndef -->
如果有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。这样最好把头文件的内容都放在#ifndef和#endif中。不管头文件会不会被多个文件引用,都要加上这个。

一般格式是这样的:
#ifndef <标识>
#define <标识>
......
......

#endif

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

#ifndef _STDIO_H_
#define _STDIO_H_

......

#endif

情况五:

在#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文件中。


转自http://hi.baidu.com/taney/blog/item/1a06abee1763d92a2df534b7.html



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics