##和#的作用
// #表示:对应变量字符串化 // ##表示:把宏参数名与宏定义代码序列中的标识符连接在一起,形成一个新的标识符 #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