编译预处理之include指令的使用与宏定义详解

/*

**test25.cpp : Defines the entry point for the console application.

**系统winXP SP3 32位.

**编译预处理之include指令的使用与宏定义详解

*/

#include "stdafx.h" //include指令用于包含一个文件

#include "iostream.h"


#define OUTPUT ("testoutput;") //这里会将;视为宏定义OUTPUT的一部分一同输出

//注意这里如果写成#define OUTPUT ("testoutput");会出现错误,会导致下面的cout输出语句提前遇到结束符;

#define PI 3.14

#define PI_2 (2 * PI)


#define ADD 1+2


//#define TEXT (str)#str   

//带参数的宏,错误

#define TEXT(str)#str   

//带参数的宏,正确,宏名与左括号之间不能有空格,否则会出现错误。

#define PLUS(x) x*x

//看个有趣的,这里注意宏定义里面尽量减少自增自减操作,否则会造成下面的状况


//#undef ADD    //取消宏定义


int main(int argc, char* argv[])

{

cout<<OUTPUT<<endl; //testoutput;

cout<<PI_2<<endl; //6.28


cout<<ADD<<endl; //3

cout<<ADD*3<<endl; //7,宏定义是直接替换所以这里的值是1+2*3,先算的乘法。


cout<<TEXT(hello)<<endl; //hello


cout<<PLUS(3)<<endl; //9

int iNum = 2;

cout<<PLUS(iNum++)<<endl; //4

cout<<iNum<<endl; //4



return 0;

}


Tips1:include指令一般用于包含一个头文件,头文件中一般包含模块的接口,编译器执行到这里就会将包含的头文件文本内容直接替换这句指令。有两种形式,1.include “xxx.h”这种一般是包含开发环境的头文件,提示编译器在开发环境设定的搜索路径搜索所需要的头文件。2.include <xxx.h>这种一般用于包含自己写的头文件,优先在当前工作目录下搜索,找不到的话再去编译环境定义的路径搜索。

Tips2:当程序包含多个头文件时候,可能会有类型重复定义的错误出现(即相同的内容在不同文件中均有定义),这就需要内部包含卫哨与外部包含卫哨。

Tips3:内部包含卫哨:实际为使用预处理器的一种标志宏。有了内部包含卫哨,会使得我们可以在一个编译单元及其包含的头文件中多次包含一个头文件而不必考虑重复定义的错误和编译后文件的过大。如下:

{1.h}----/**#ifdef  _1_H_INCLUDE_

#def  _1_H_INCLUDE_

//头文件内容

#endif

**/

{1.cpp}/**#include 1.h

#include 1.h  //不会造成重复定义,多个文件包含也是一样。

**/

Tips4:外部包含卫哨:当包含一个头文件时候,如果使用外部包含卫哨会增加程序执行效率,因为当一个源文件反复包含一个头文件时候,会造成递归替换的现象发生。

/**

#if !defined (_1_H_INCLUDE_)

#include <1.h>

#define _1_H_INCLUDE_

#endif

**/

Tips5:宏定义define:宏定义不是C语言语句,因此不需要;结束符,否则会被视为宏定义的一部分。宏定义以define关键字后面出现的第一个。

推荐阅读更多精彩内容