1. 文件准备:
- 测试代码:
 

- Makefile文件:
 

- 执行结果:
 

此时,我们的结果是存在问题的,即最终结果少了100。现在我们用gdb来调试它。

我们发现我们还没有安装gdb,这里安装一下。
2. 环境准备:
sudo yum install -y gdb
作用:安装gdb。
![]()
gdb 【目标文件】
作用:开始调试可执行目标文件。

q
作用:退出调试。

但是,此时gdb还调试不了。因为在linux中,gcc/g++生成的软件,默认是release版本的。
这里需要在gcc命令后面跟上 -g ,标识以debug方式发布。

为了和原来的release版本做区分,我们这里将可执行目标文件的名称改为 mytest_g 。
 
同时,我们也会发现debug版本的程序的大小大于release版本的程序的大小。
原因在于debug版本要加入更多的调试信息。
证明:
readelf -S 【可执行文件名】
作用:读取可执行程序的二进制构成 。
release版本:

debug版本:


通过grep过滤,我们发现debug版本的可执行程序的确比release版本的可执行程序多了调试信息。
3 命令大全:
- list/l 行号:显示源代码,接着上次的位置往下列,每次列10行。
 - list/l 函数名:列出某个函数的源代码。
 - r/run:运行程序。
 - n / next:单条执行。
 - s/step:进入函数调用
 - break/b 行号:在某一行设置断点
 - break/b 函数名:在某个函数开头设置断点
 - info break :查看断点信息。
 - finish:执行到当前函数返回(把当前函数跑完),然后停下来等待命令
 - print/p:打印表达式的值,通过表达式可以修改变量的值或者调用函数
 - p 变量:打印变量值。
 - set var:修改变量的值
 - continue/c:从当前位置开始连续而非单步执行程序
 - run/r:从开始连续而非单步执行程序
 - delete breakpoints/d:删除所有断点
 - delete breakpoints n/d n:删除序号为n的断点
 - disable breakpoints:禁用断点
 - enable breakpoints:启用断点
 - info/i breakpoints:参看当前设置了哪些断点
 - display 变量名:跟踪查看一个变量,每次停下来都显示它的值
 - undisplay:取消对先前设置的那些变量的跟踪
 - until X行号:跳至X行
 - breaktrace/bt:查看各级函数调用及参数
 - info/i locals:查看当前栈帧局部变量的值
 - quit/q:退出gdb
 



















