【问题标题】:What do the numbers mean in the preprocessed .i files when compiling C with gcc?使用 gcc 编译 C 时,预处理的 .i 文件中的数字是什么意思?
【发布时间】:2016-01-10 09:46:05
【问题描述】:

我正在尝试了解编译过程。我们可以使用以下命令查看预处理器中间文件:

gcc -E hello.c -o hello.i

cpp hello.c > hello.i

我大致知道预处理器的作用,但我很难理解某些行中的数字。例如:

 # 1 "/usr/include/stdc-predef.h" 1 3 4
 # 1 "<command-line>" 2
 # 1 "hello.c"
 # 1 "/usr/include/stdio.h" 1 3 4
 # 27 "/usr/include/stdio.h" 3 4
 # 1 "/usr/include/features.h" 1 3 4
 # 374 "/usr/include/features.h" 3 4

数字可以帮助调试器显示行号。所以我对第一列的猜测是第 2 列文件的行号。但是下面的数字有什么作用呢?

【问题讨论】:

标签: c gcc compilation c-preprocessor


【解决方案1】:

文件名后面的数字是标志:

1:这表示一个新文件的开始。

2:这表示返回到一个文件(在包含另一个文件之后)。

3:这表示以下文本来自系统头文件,因此应禁止某些警告。

4:这表示应将以下文本视为包含在隐式extern "C" 块中。

来源:https://gcc.gnu.org/onlinedocs/cpp/Preprocessor-Output.html

【讨论】:

  • 谢谢。这是非常有用的信息。我仍在试图了解这些如何融入图片。你能解释一下吗?我还将根据您的来源继续我的研究,看看这些标志是如何被解释的。
  • 我相信 1 和 2 标志是为了让人们了解包含文件的嵌套性质,所以很明显谁包含了谁。系统头文件可能包含非标准构造,因此 3 标志告诉编译器这些构造在该上下文中是可接受的。由于头文件可以包含在 C 或 C++ 源代码中,因此 4 标志让 C++ 编译器知道不执行任何名称修改。
  • 最新版本的 gcc 可以使用“嵌套性质”来显示问题所在的连续包含文件。这是否有用值得商榷,因为较新的版本没有提供更新的类型检查或更好的分析,因此只会放大现有的小问题。
  • 由于缺乏知识,目前我无法消化太多。会继续我的学习。谢谢大家。
猜你喜欢
  • 1970-01-01
  • 2021-08-11
  • 2019-10-23
  • 1970-01-01
  • 1970-01-01
  • 2013-09-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多