这是一个简单的小C程序让我困惑了一段时间:
#include <stdio.h>
#define STR1(x) #x
#define STR(x) STR1(x)
int main(void) {
printf("%s\n", STR(MYDEF));
}
Run Code Online (Sandbox Code Playgroud)
这只是使用标准的字符串化双定义技术将MYDEF #define的值打印为字符串.
编译(在Linux上)gcc -DMYDEF=abc prog.c运行结果,毫不奇怪,它打印出'abc'.
但是更改值gcc -DMYDEF=linux prog.c并且打印的结果不是'linux'而是'1'.
所以这让我感到困惑,但当然这是因为我发现gcc(在Linux上)有一个内置的#define,名为'linux',值为'1',STR(x)宏最终将MYDEF扩展到'linux'然后将linux扩展为'1'.
在我的真实程序中(这比上面的小测试复杂得多)我通过以不同(可能更好)的方式做事来绕过这个,但它让我很好奇...是否有一个简单的小宏技术可以避免这个双重替换并使程序打印出'linux'?我知道我可以添加Linux的-U或#undef,但这感觉有点笨拙.
我原以为所有内置的#defines都以下划线(通常是双下划线)开头,但我猜不是.