如何测试 C 预处理器 -D 标志值?

How to test C Preprocessor -D flag value?

我有以下 .c 文件:

$ cat hellomake.c 
#include <stdio.h>

#ifdef REVISION
#warning defined
#else
#warning not defined
#endif

#if REVISION==C0
#warning using C0
char str[] = "c0";
#else
#warning using B0
char str[] = "b0";
#endif

void main(void)
{
    printf("%s\n", str);
}

我使用这个 Makefile 构建它:

$cat Makefile 
REVISION=B0

all: hellomake.c
    gcc -o hellomake hellomake.c -DREVISION=$(REVISION)

构建显示预处理器通过#if REVISION==C0 分支,而不是通过#else 分支:

$ make all
gcc -o hellomake hellomake.c -DREVISION=B0
hellomake.c:4:2: warning: #warning defined [-Wcpp]
    4 | #warning defined
      |  ^~~~~~~
hellomake.c:10:2: warning: #warning using C0 [-Wcpp]
   10 | #warning using C0
      |  ^~~~~~~

执行二进制文件也显示出同样奇怪的行为:

$ ./hellomake 
c0

我的问题是,这怎么可能?为什么 #if REVISION==C0 值测试不能正常工作?我期待预处理器打印“使用 B0”,二进制执行结果为“b0”。

C 预处理器不进行字符串比较。相反,B0C0 被解释为未定义的宏标识符,值为 0。因此,当 REVISION==C0 扩展为 B0==C0 时,它变为 0==0,这是正确的.如果你想要可比较的东西,你需要使用整数。参见:https://gcc.gnu.org/onlinedocs/gcc-3.0.2/cpp_4.html#SEC38