参考自: http://zjf30366.blog.163.com/blog/static/411164582009061075923/
#include<cstdio>
#include<iostream>
using namespace std;
#define f(a,b) a##b
#define d(a) #a
#define s(a) d(a)
int main()
{
int xy = 10;
cout<< f(x,y) << endl;
puts( d(f(a,b));
puts( s(f(a,b) );
}
输出
10
f(a,b)
ab
分析:
1 # 和 ## 操作符是和#define宏使用的. # 使在#后的首个参数返回为一个带引号的字符串; ##把两个符号连起来是把##前后两个符号连接起来
2 第一行输出没有什么好解释的,后两行输出我看网上有两种解释
(1)从##角度解释
puts(d(f(a,b))); ----> 因为d宏中的参数是另外一个宏,且带##,所以作为参数的宏不展开,相当于 puts(#f(a,b));----->puts("f(a,b)");
puts(s(f(a,b))); ----> 因为s宏中的参数是另外一个宏,但不带##,所以作为参数的宏先展开,相当于 puts(s(ab));----->puts(d(ab));---->puts(#ab);---->puts("ab");
(2)从#角度解释
#define f(a,b) a##b
#define d(a) #a --》 以"#"开头的,直接替换,不展开:immediately replaced by the unexpanded actual argument
#define s(a) d(a) --》 非以"#"开头的,先展开,再替换,也就是一般的情况
所以就两种情况:
1,不以"#"开头的,先展开参数a,然后是替换代码:puts(s(f(a,b)));-->puts(s(ab))-->puts(d(ab))-->puts("ab")
2,以"#"开头的,直接替换,不展开:puts(d(f(a,b)))-->puts("f(a,b)")