Linux之基础开发工具(Ubuntu)之编译器

编译器:

我们知道代码运行的时候需要进行

1.预处理------替换宏、头文件的展开、去注释

2.编译------生成汇编

3.汇编------生成机械码

4.链接------生成可执行文件/库文件

至于为什么要这么麻烦,还得从历史说。在早期只有手动操作的时候,相当于输入机械码,直到后面出现汇编语言,所以需要用机械码来翻译汇编语言,应为计算机只认识机械码,后买你高级语言同样如此,需要先由汇编来处理,在翻译成机械码。

而我们今天所学的编译器将按照这个进行过程一一学习,利用gcc来手动完成

格式:

gcc 选项 要编译的⽂件 选项 ⽬标⽂件

1.预处理:

gcc -E 要编译的文件 -o 目标文件

-o代表后面接的是目标文件,所以这个指令可以写成 gcc -o 目标文件 -E 要编译的文件,只需要谨记指令后面接上对应的文件就行。

一般而言预处理后的文件后缀是 .i,for example :gcc -E code.c -o code.i

2.编译

gcc -S 预处理生成的文件 -o 目标文件

3.汇编

gcc -c 编译生成的文件 -o 目标文件

4.链接

gcc 汇编生成的文件 -o 可执行文件

其实在真实的环境下,我们往往是这样操作的

gcc -o code.o code.c

直接从.c 文件到.o文件,在这个状态下进行多文件的链接,生成可执行文件

如何进入调试?

使用gdb,但这就要求我们汇编是后二进制文件的时候加上-g选项,因为默认gcc/g++生成的是release模式,想要调试,就要进入debug模式

gcc code.c -o

cgdb 目标文件

这里要说的是cgdb是要apt的

你自己想一下如何下载?

apt install -y cgdb

接下来就是学习如何使用cgdb

断点

b -n ------断点

info b ------查看断点

delete -n ------删除编号为 n 的断点

delete 不加编号,默认删除所有的断点;加入编号,就是删除指定断点。

disable -n ------禁用编号为 n 的断点,适合用于现在不想要删除断点,但是目前不想使用这个断点

enable -n ------恢复使用编号为 n 的断点

(不加编号的话,对象都是默认对所有的断点)

下面的图可以看出第一个断点是行号为 4 的,使用disable后没有删除这个断点,但是 r 后执行到了第二个断点标记的行号

enable 回复使用

现在你想要某个断点在特殊条件下才能执行,如何操作?

1.对于没有标记过的

b -n if 条件

2.对于已经存在的断点,想要添加条件

condition 编号 条件

运行

r ------如果没有运行到第一个断点,会自动运行到第一个断点;如果已经运行到第一个断点,会弹出选项,是选择重新运行到第一个断点,还是运行完。

c ------ 从当前位置开始往后执行断点,但第一步需要run

n ------单步执行,自动跳过函数

s ------单步执行,进入函数内部

until -n ------表示直接运行到第n行,这个还是比较常用的

如果你想要监视变量

display 变量名

undisplay -n 编号

watch 变量------只要这个变量的值发生变化就会跳出提醒,相当于监视这个变量

退出:

quit

相关推荐
AlfredZhao18 小时前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐2 天前
Linux内存扩容指南
linux
zylyehuo2 天前
Linux 彻底且安全地删除文件
linux
用户805533698033 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297913 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
乘云数字DATABUFF3 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Web3探索者5 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo5 天前
Linux系统中网线与USB网络共享冲突
linux
荣--5 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森5 天前
动手实战学 Docker — 从零到集群编排完全指南
运维