一、分析[-v] 打印出来的代码[生成编译]
/usr/lib/gcc/x86_64-linux-gnu/8/cc1 -quiet -v -imultiarch x86_64-linux-gnu welcome.c -quiet -dumpbase welcome.c -mtune=generic -march=x86-64 -auxbase welcome -version -o /tmp/ccBwcsMD.s
注意1:这个将“.c”文件是input,“-o”输出文件将它临时存储成“.s”文件。
注意2:以上是类似与gcc -S -o 的参数。
二、接着分析后面的打印的代码文件[生成汇编]
as -v --64 -o /tmp/ccTEFvJw.o /tmp/ccBwcsMD.s
注意1:这里的“.s”文件是前面“-o”(output)输出分析出来的。
注意2:简略写成:as -o ccTEFvJw.o ccBwcsMD.s(生成汇编文件)。
注意3:以上的生成汇编命令是 gcc -c,这个“-c”相当于间接的调用as。
注意4:“-c”参数只能把“.s”翻译成“.o”文件,不可能把“.c”翻译成“.o”。
- 接着分析后面的打印代码文件[生成链接]
/usr/lib/gcc/x86_64-linux-gnu/8/collect2 -o build +其他链接文件
注意1:以上类似与gcc -o 参数。
- 总结分析步骤是
先编译--->再汇编--->最后链接。
- 实战编译过程
- gcc -S -o
|
|
2.gcc -c -o

注意:“.o”是一个二进制文件。其实就是将人看懂的文件翻译成机器懂的内容。
3.gcc -o

- 预处理
- 使用cpp命令生成预处理文件

注意1:cpp -o 类似与gcc -E。
注意2:当生成了“.i”文件后才是生成“.s”文件。
- 实战构建预处理内容并使用gcc -E输出
- 修改welcome.c文件如下
|
#include <stdio.h> |
2.使用gcc -E 命令输出

3.查看build.i 文件
注意1:这里写的预处理指令没有了,其实预处理做的就是文件替换。
注意2:在编译的过程中已经没有预处理的文件替换过程了。
注意3:define 和 include 不是关键字因为它是预处理使用的,而关键字是在编译过程中使用的。
本文详细解析了GCC编译器将C源代码转化为可执行文件的过程,包括预处理、编译、汇编和链接四个阶段。通过实例展示了gcc命令的不同选项如何影响这一流程,如-S生成汇编代码,-c生成目标文件,-o用于指定输出。预处理阶段主要处理宏定义和头文件包含,编译阶段将预处理后的代码转换为汇编语言,汇编阶段将汇编代码转为目标代码,链接阶段则将目标代码与其他库文件结合生成最终的可执行文件。

1824

被折叠的 条评论
为什么被折叠?



