#define是预处理器单元实体之一,可出现在任意位置。
#define定义之后的代码都能使用这个宏。
#define定义的宏常量本质是字符量,即不占用内存空间。
#define有比函数更加强大的地方比如计算数组的长度,但是更容易出错。如
#define _DIM_(a) sizeof(a)/sizeof(*a)
下面,我们再来看一个小程序
#include<stdio.h>
#define _SUM_(a, b) (a)+(b)
#define _MIN_(a, b) a<b?(a):(b)
#define _DIM_(a) sizeof(a)/sizeof(*a)
int main(){
int a = 1;
int b = 5;
int c[4] = {1};
printf("%d\n", _SUM_(a, b)*_SUM_(a, b));
printf("%d\n", _SUM_(a, b));
printf("%d\n", _MIN_(a++, b));
printf("%d\n", _DIM_(c));
return 0;
}
分析一下程序,按照正常的理解,输出结果应该是36,6,1,以及4,但是真的是这样吗?
[lin@bogon C]$ ./a.out
11
6
2
4
以上就是上面程序的输出结果,怎么跟预想中的结果不大一样呢。那么,接下来,我们看看预编译的结果。
int main(){
int a = 1;
int b = 5;
int c[4] = {1};
printf("%d\n", (a)+(b));
printf("%d\n", a++<b?(a++):(b));
printf("%d\n", sizeof(c)/sizeof(*c));
printf("%d\n", (a)+(b)*(a)+(b));
return 0;
}
从上图中,我们可以看出,预编译之后,所有的#define定义,直接进行文本替换二部进行计算。难怪跟我们设想中的结果不一样。
最后,总结一下
- 宏表达式被预处理器处理(文本替换)
- 宏表达式用“实参”完全代替形参,且不进行计算
- 宏表达式相对函数来说,没有任何的“调用”开销
- 宏定义中不能出现递归。 如
#define _Sum_(n) ((n>0)?(_Sum_(n-1)+n):0)