// #表示:对应变量字符串化
// ##表示:把宏参数名与宏定义代码序列中的标识符连接在一起,形成一个新的标识符
#include <stdio.h>
#define trace(x, format) printf(#x " = %" #format "\n", x)
#define trace2(i) trace(x##i, d)
int main()
{
int i=1;
char *s="three";
float x=2.0;
trace(i, d); // 相当于 printf("x = %d\n", x)
trace(x, f); // 相当于 printf("x = %f\n", x)
trace(s, s); // 相当于 printf("x = %s\n", x)
int x1=1, x2=2, x3=3;
trace2(1); // 相当于 trace(x1, d)
trace2(2); // 相当于 trace(x2, d)
trace2(3); // 相当于 trace(x3, d)
return 0;
}
我的编辑环境vs2008 +win32位系统:
在程序中打断点,启动debug模式,在该模式下可以进行反汇编(Alt+8)观察程序,能够更加深入理解程序的编译情况,图1是反汇编的一部分程序。
红色标出的部分即是经过编译器编译的机器码,可以看出传递给可变函数的参数是一个格式化字符串。
形如printf("1" "1")可变参数的函数参数,可以是多个字符串的拼接, 即使中间包含空格,经过编译器编译,printf参数为“11”,将两个字符串拼接在一起了。反汇编结果得到验证,结果如下:
参考博客:
http://blog.csdn.net/huang_xw/article/details/7648179