##和#的作用

// #表示:对应变量字符串化
// ##表示:把宏参数名与宏定义代码序列中的标识符连接在一起,形成一个新的标识符
#include <stdio.h>
#define trace(x, format) printf(#x " = %" #format "
", 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
", x)
	trace(x, f);				// 相当于 printf("x = %f
", x)
	trace(s, s);				// 相当于 printf("x = %s
", 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
原文地址:https://www.cnblogs.com/jinxiang1224/p/8468395.html