尚硅谷Linux应用层学习笔记(一)GCC编译

一、编译流程

.c源文件 => 预处理 => 编译 => 汇编 => 链接 => 可执行文件

1. 预处理 gcc -E

cpp 复制代码
# 预处理main.c,得到预处理后的文件main.i
# .i为预处理文件的统一后缀

gcc -E main.c -o main.i 

有以下目的:

  • 调试宏定义是否展开
  • 查看引入.h文件后的完整代码
  • 排查条件编译引入的问题

2. 编译 gcc -S

cpp 复制代码
# 编译main.c,生成编译后的汇编文件main.s
# .s为汇编文件的后缀
gcc -S main.c -o main.s

这一步主要用来分析汇编代码

3. 汇编(生成目标文件但不进行链接) gcc -c

cpp 复制代码
# 汇编main.c,输出目标文件main.o
gcc -c main.c -o main.o

将各.c文件编译为.o文件,各个.o文件链接后生成可执行文件

4. 链接

链接的操作就是将各个.o文件内相互引用的函数、变量等链接起来,找到各自的符号,然后再输出一个可执行文件。

二、objdump工具

  1. 反汇编二进制文件(代码段)
  2. 查看源码的section信息
  3. 查看符号表查看头文件

三、静态链接与动态链接

  1. 静态链接

GCC会尝试将所有用到的库函数直接链接到最终生成的可执行文件中

  1. 动态链接

库只有在被调用时才被加载进文件中,而不是全部加载到文件中进行编译。所以动态链接的可执行文件比静态链接的小。

main为静态链接,main1为动态链接,二者.c文件相同,但不同的链接方式造成编译后文件出现较大的体积差异,主要是因为静态链接将stdio内的函数链接到了可执行文件中。

相关推荐
SudosuBash21 小时前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI1 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行2 天前
Linux和window共享文件夹
linux
木心月转码ing2 天前
WSL+Cpp开发环境配置
linux
崔小汤呀3 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
何中应3 天前
vi编辑器使用
linux·后端·操作系统
何中应3 天前
Linux进程无法被kill
linux·后端·操作系统
何中应3 天前
rm-rf /命令操作介绍
linux·后端·操作系统
何中应3 天前
Linux常用命令
linux·操作系统
葛立国3 天前
从 / 和 /dev 说起:Linux 文件系统与挂载点一文理清
linux