https://blog.csdn.net/seekkevin/article/details/17611935
1 #define命令剖析
1.1 #define的概念
define命令是C语言中的一个宏定义命令,它用来将一个标识符定义为一个字符串,该标识符被称为宏名,被定义的字符串称为替换文本。
该命令有两种格式:一种是简单的宏定义,另一种是带参数的宏定义。
(1) 简单的宏定义:
define <宏名> <字符串>
例: #define PI 3.1415926
(2) 带参数的宏定义
define <宏名> ( <参数表>) <宏体>
例: #define A(x) x
一个标识符被宏定义后,该标识符便是一个宏名。这时,在程序中出现的是宏名,在该程序被编译前,先将宏名用被定义的字符串替换,这称为宏替换,替换后才进行编译,宏替换是简单的替换。
===================================================
2.define的“函数定义”
define可以像函数那样接受一些参数,如下
define max(x,y) (x)>(y)?(x):(y);
这个定义就将返回两个数中较大的那个,看到了吗?因为这个“函数”没有类型检查,就好像一个函数模板似的,当然,它绝对没有模板那么安全就是了。可以作为一个简单的模板来使用而已。
但是这样做的话存在隐患,例子如下:
define Add(a,b) a+b;
在一般使用的时候是没有问题的,但是如果遇到如:c * Add(a,b) * d的时候就会出现问题,代数式的本意是a+b然后去和c,d相乘,但是因为使用了define(它只是一个简单的替换),所以式子实际上变成了
ca + bd
另外举一个例子:
define pin (int*);
pin a,b;
本意是a和b都是int型指针,但是实际上变成int* a,b;
a是int型指针,而b是int型变量。
这是应该使用typedef来代替define,这样a和b就都是int型指针了。
所以我们在定义的时候,养成一个良好的习惯,建议所有的层次都要加括号。
3.宏的单行定义
define A(x) T_##x
define B(x) #@x
define C(x) #x
我们假设:x=1,则有:
A(1)------〉T_1
B(1)------〉‘1’
C(1)------〉“1”
注意:#define语句中的#是把参数字符串化,##是连接两个参数成为一个整体。@#字符化操作符,将传的单字符参数名转换成字符,以一对单引用括起来。。
=================================
4.define的多行定义
define可以替代多行的代码,例如MFC中的宏定义(非常的经典,虽然让人看了恶心)
define MACRO(arg1, arg2) do { /
/* declarations / /
stmt1; /
stmt2; /
/ … / /
} while(0) / (no trailing ; ) */
关键是要在每一个换行的时候加上一个”/”
===================================================
5.在大规模的开发过程中,特别是跨平台和系统的软件里,define最重要的功能是条件编译。
就是:
ifdef WINDOWS
……
……
endif
ifdef LINUX
……
……
endif
可以在编译的时候通过#define设置编译环境
6.如何定义宏、取消宏
//定义宏
define [MacroName] [MacroValue]
//取消宏
undef [MacroName]
普通宏
define PI (3.1415926)
带参数的宏
define max(a,b) ((a)>(b)? (a),(b))
关键是十分容易产生错误,包括机器和人理解上的差异等等。
7.条件编译
ifdef XXX…(#else) …#endif
例如 #ifdef DV22_AUX_INPUT
define AUX_MODE 3
else
define AUY_MODE 3
#endif
ifndef XXX … (#else) … #endif
==============================================
8.头文件(.h)可以被头文件或C文件包含;
重复包含(重复定义)
由于头文件包含可以嵌套,那么C文件就有可能包含多次同一个头文件,就可能出现重复定义的问题的。
通过条件编译开关来避免重复包含(重复定义)
例如
ifndef headerfileXXX
#define headerfileXXX
…
文件内容
…
endif
================================================