##和#的作用

// #表示:对应变量字符串化
// ##表示:把宏参数名与宏定义代码序列中的标识符连接在一起,形成一个新的标识符
#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
posted @ 2016-08-01 21:56  小怪兽&奥特曼  阅读(395)  评论(0编辑  收藏  举报