是道编译预处理的问题
#define PRI printf
#define NL "\n"
#define D "%d"
#define D1 D NL
#define D2 D D NL
#define D3 D D D NL
#define D4 D D D D NL
#define S "%s"
main()
{int a,b,c,d;
char string[]="china";
a=1;b=2;c=3;d=4;
PRI(D1,a);
PRI(D2,a,b);
PRI(D3,a,b,c);
PRI(D4,a,b,c,d);
PRI(S,string);
}
这是道挺普通的编译预处理的问题,以前都没觉得什么,可那天忽然很认真地将他全部代换过来后发现问题
比如:
PRI(D1,a);
这个代换过来之后是
printf("%d" "\n",a);
应该是这样没错吧,那么里面的两对双引号要怎么处理呢???
难道不会把第2和第3个双引号包括那个空格,都当成字符原样输出吗???
大家不要笑话我傻呀~~~~
期待回话,谢谢!!
----------------解决方案--------------------------------------------------------
#include<stdlib.h>
#include<stdio.h>?
#define D "%d"
#define C "uuuu\n"
#define a(s,f) s##f
int main()
{
printf(D,12);
printf(C);
printf(a(D,C),12);
}
----------------解决方案--------------------------------------------------------
问得好!我也不知道!
----------------解决方案--------------------------------------------------------
不明白为什么要转换,不过觉得写这个“printf("%d" "\n",a);”语句怪怪的,为什么要加那么多双引号?如果要输出双引号应该要加转义字符吧?,我也不是很懂,互相切磋吧!
----------------解决方案--------------------------------------------------------
是一个字符串的拼接,D和NL相当于字符串
D1=“%d\n”
将D的所以字符输出就可以看到结果
----------------解决方案--------------------------------------------------------
#include<stdlib.h>
#include<stdio.h>?
#define D "%d"
#define C "uuuu\n"
#define a(s,f) s##f //这里的##是什么意思?
int main()
{
printf(D,12);
printf(C);
printf(a(D,C),12);
}
----------------解决方案--------------------------------------------------------
连接标记
----------------解决方案--------------------------------------------------------
标记===>token
----------------解决方案--------------------------------------------------------
还有其他的连接标记么?
----------------解决方案--------------------------------------------------------
呀呀~~~~~~~~~~~高手~~~~~~~~~~~~~~字符串拼接~~~~好,去查查看,不明白再问的哦~~~~~~
----------------解决方案--------------------------------------------------------