前言
在VS系列的IDE中,我们习惯于图形化窗口的调试;而在linux的命令行下,我们则借助gdb这个工具来完成程序的调试
阅读完本文,你将了解:
- 显示代码
- 打断点、跳转到断点
- 逐过程执行
- 逐语句执行
- 长显示变量信息
- 跳转到指定行
- 禁用断点
- 调试时更改变量
1.如何将源码编译成可调试的二进制文件
我们以前在编译一个C语言源文件mytest.c时,通常使用这条指令:
gcc mytest.c -o mytest
顺利生成了可执行文件
mytest
如果我们直接使用gdb调试这个可执行文件,会发现没有调试信息:
这是为什么呢?
Linux中程序默认编译的时候
- 默认生成的可执行程序是release版本的,不可调式
所以
- 需要调试,gcc编译时需要加
-g
参数,以debug方式发布程序,使得可执行文件带有调试信息–>才可以被gdb追踪,调试,即:
gcc mytest.c -o mytest_debug -g
我们还可以发现的是,debug版本的可执行文件比release版本的大一些,这就是因为添加了调试信息
2.开始调试
首先给一下源文件:
#include<stdio.h>intsum(int top){int _sum =0;int i =0;for(;i <= top; i++){
_sum += i;}return _sum;}intmain(){int max =0;printf("please enter your data# ");scanf("%d",&max);int _sum =sum(max);printf("1:%d\n", _sum);printf("2:%d\n", _sum);printf("3:%d\n", _sum);printf("4:%d\n", _sum);printf("5:%d\n", _sum);printf("6:%d\n", _sum);return0;}
我们先编译生成带调试信息的可执行文件
gcc mytest.c -o mytest_debug -g
然后gdb调试:
gdb mytest_debug
命令作用list/l显示源代码(一次10行)run/r运行程序next/n逐过程执行step/s逐语句执行,可进入函数内break/b 行号在某一行设置断点info break查看断点信息finish执行到当前函数返回print/p打印表达式的值set var修改变量的值continue跳到下一个断点delete breakpoints删除所有断点delete breakpoints n删除序号为n的断点disable breakpoints n取消对序号为n的断点的追踪enable breakpoints n恢复对序号为n的断点的追踪info breakpoints打印设置的断点display 变量名长显示某变量undisplay变量名取消对某变量的长显示until 行号跳至某行quit/q退出gdb
下面演示常用命令
2.1 显示代码 l
list/l 行号
显示源代码,一次显示10行,再按回车会接着往下显示
2.2 运行程序 r
我们开始调试,也就是要运行程序:
run/r
我们发现,r之后,代码直接执行到了第14行的输入语句,并且输入之后程序直接结束,根本没有进行调试。原因是因为我们没有设置断点,如果设置了断点,r将会执行到第一个断点处停止,这样我们就能进行单步调试。
2.3 设置、查看断点
b 行号 //设置断点
info b //查看断点
我们在14、15、19行设置了断点
2.4 next单步逐过程调试
我们继续r执行程序,再n单步执行
n
发现n没有让我们进入函数体内,这说明了n是逐过程调试
2.5 step逐语句调试
我们用s进入函数体内
2.6 finish执行到当前函数返回停下
finish
2.7 c跳到下一个断点
c
2.8 dispaly 长显示变量
display 变量名
undisplay 变量序号
注意undisolay的是变量前面的序号
2.9 打印表达式的值 p
版权归原作者 DanteIoVeYou 所有, 如有侵权,请联系我们删除。