我曾认为cpp foo.c
和gcc -E foo.c
两者对源文件的预处理方式相同,但是我发现它们对于同一个文件的输出结果不同。
$ cat foo.c
#define VARIABLE 3
#define PASTER(x,y) x ## _ ## y
#define EVALUATOR(x,y) PASTER(x,y)
#define NAME(fun) EVALUATOR(fun, VARIABLE)
extern void NAME(mine);
cpp
的结果:
$ cpp foo.c
# 1 "foo.c"
# 1 "<built-in>" 1
# 1 "<built-in>" 3
# 329 "<built-in>" 3
# 1 "<command line>" 1
# 1 "<built-in>" 2
# 1 "foo.c" 2
extern void mine ## _ ## 3;
$
gcc -E
和 clang -E
的结果:
$ gcc -E foo.c
# 1 "foo.c"
# 1 "<built-in>" 1
# 1 "<built-in>" 3
# 330 "<built-in>" 3
# 1 "<command line>" 1
# 1 "<built-in>" 2
# 1 "foo.c" 2
extern void mine_3;
$
为什么这些输出不同,当我想要查看预处理后的源代码时应该使用哪一个?
原始代码在这里。
cpp
版本生成的输出与gcc -E
相同。与你的gcc
输出相同。 - selbiecpp foo.c
和gcc -E foo.c
得到了相同的结果。你能把cpp -v foo.c
的输出粘贴到问题中吗? - Michael Burr--traditional-cpp
,我会得到与您相同的输出。看起来有人已经将其确定为可能的答案了。 - selbiecpp -v foo.c
的第一行是Apple LLVM version 8.0.0 (clang-800.0.42.1)
。其余输出内容相当冗长。 - Bilow