最近使用GDB比较多,发现除了最常用的run、break、continue、next等命令的基本用法外,还有一些非常有用的命令和用法,能让你更加得心应手地使用GDB,在这里做了一下简单的总结。

1. run

当GDB的程序需要带参数运行时,除了使用set args外,还可以直接在run(r)后面带上参数,如下面两种方式是等价的:

2. set follow-fork-mode

有时候会发现GDB无法跟踪到设置的断点,原因可能是需要调试的进程是daemon进程或者fork的子进程,而GDB默认是只会Attach到父进程的。如果要调试子进程,必须在run之前设置follow-fork-mode,执行命令set follow-fork-mode child后在运行程序,就可以一路跟踪fork出的子进程;相对地,如果想停留在当前进程而不再进入子进程,则执行set follow-fork-mode parent即可。

3. print

print可以打印出当前上下文的变量值,print非常强大,除了打印整形等内置变量的值,还可以直接打印出结构体或类对象的值,如:

上图中的结构体有些复杂,打出来的格式不够清晰明了,这时就要使用set print pretty on,设置之后,打印出来的结构体的可读性就好了很多:

在上面的结构体中,buffer数组中的每个字节默认以字符的方式打印,如果是不可打印字符,则输出ASCII码,我们可能想直接打印出实际的二级制值,print可以设置输出数据的格式,如输出为十六进制(x)和十进制(d):

对于数组的输出,p array打印数组的所有元素,p array[i]打印下标为i的元素,如果想打印一段范围的元素,可以使用p array[i]@len,如:

print不仅可以打印变量的值,还可以直接打印函数和类成员方法的返回值,如:

4. finish

在单步调试时,除了next,还可以通过step进入到函数的内部,如果进入到一个很长的函数,而又想跳出该函数,我原来的做法是在调用的函数的下一条语句设置一个断点,其实最简单的方法是使用finish就可以完成当前函数的调用。同样通过finish,我们可以快速定位到调用当前函数的代码。

5. 条件断点

设置断点是我们在使用GDB时最常用的调试手段,有时候我们希望断点在特定的条件下生效,如输入参数满足一定的条件或者循环变量为特定的值,GDB的条件断点就是为此而生的,设置条件断点的方法是break if conditon,如:

break if input>10&&input<20

break if i%100==0

6. 设置变量值

GDB是如此强大,以至于你可以根据调试思路在调试过程中动态地设置变量的值,如改变变量的值以改变程序的执行路径,有两种方式可以设置:

(1)p v=value

(2)set v=value(如果变量名和GDB内置变量冲突,使用set var v=value)

示例如下:

GDB使用技巧的更多相关文章

  1. 《软件调试的艺术》学习笔记——GDB使用技巧摘要

    <软件调试的艺术>学习笔记——GDB使用技巧摘要 <软件调试的艺术>,因为名是The Art of Debugging with GDB, DDD, and Eclipse. ...

  2. GDB调试技巧:总结篇

    目录 一 写在开头 1.1 本文内容 二 学习资料 三 常用命令 四 调试技巧 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 写在开头 1.1 本文内容 总结GDB调试的一些常用命令和调试 ...

  3. pwn 题GDB调试技巧和exp模板

    GDB分析ELF文件常用的调试技巧 gdb常用命令 首先是gbd+文件名 静态调试 ,gdb attach +文件名 动态调试 为了方便查看堆栈和寄存器 最好是安装peda插件 安装 可以通过pip直 ...

  4. GDB调试技巧

    1. 查看内存分布 (gdb) info proc mappings 2. 对于类的调试,先通过行号来设断点, 比如:(gdb) b TcpConnection.cc:63 3. 打印数组的内容 (g ...

  5. gdb调试技巧 找到php执行进程当前执行的代码

    假设线上有一段php脚本,突然在某天出问题了,不处理但是进程没有退出.这种情况可能是异常休眠或者是有段死循环代码,但是我们怎么定位呢,我们这个时候最想知道的应该是这个脚本在此刻在做什么吧.这个是gdb ...

  6. 100个gdb调试技巧

    找到的一个有参考价值的关于GDB调试的站点:https://gitlore.com/subject/15

  7. GDB 调试技巧(不断更新中......)

    一.break到不同类的同名函数 方法: 在函数前面加类名以及作用域运算符 eg : break A::func //break 到类A的func函数 程序如下: //gdb_test.cpp #in ...

  8. gdb 小技巧

    https://www.gitbook.com/book/wizardforcel/100-gdb-tips/details

  9. Linux基础 30分钟GDB调试快速突破

    引言 Linus心灵鸡汤 在*nix开发中有道卡叫gdb调试,不管你怎么搞. 它依然在那丝毫不会松动.今天致敬一个 活着的传奇 Linus Torvalds Unix 始于上个世纪60年代,在70年代 ...

随机推荐

  1. POJ - 1321 棋盘问题 简单搜索 dfs 格子

    点这里去看题 思路:本题的难点在k<n的情况,所以我们可以另dfs中的两个参数分别代表起始行和待放棋子个数(待放棋子只能放在起始行后面的行),然后用一个c[8]来表示每一列放旗子的情况来判断列不 ...

  2. ajax 删除数据无刷新

    //html页面 <!doctype html><head> <title></title> <meta http-equiv="Con ...

  3. 一篇入门 -- Scala

    整体介绍 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性. 联邦理工学院洛桑(EPFL)的Martin Odersky于2001 ...

  4. JavaScript操作和使用Cookie

    Cookie概述 Cookie是由服务器端生成并储存在浏览器客户端上的数据. 在javaweb开发中Cookie被当做java对象在web服务器端创建,并由web服务器发送给特定浏览器客户端,并且we ...

  5. centos部署flask

    1.先安装uwsgi pip install uwsgi 2.在你的项目根目录下创建一个配置文件uwsgiconfig.ini(uwsgi支持多种配置文件格式,xml,ini,json等) [uwsg ...

  6. linux下静态链接库和动态链接库

    关于链接库的知识,网上太多资料了,但是并不代表我很熟悉.今天遇到了 一个问题,就是由于静态链接库和ubuntu系统不兼容导致的,虽然花了点时间才搞定 但是,其中暴露的问题也不少. 没有区分好静态链接库 ...

  7. Testing - 软件测试知识梳理 - 测试模型

    珠玉在前,不再赘言. 软件测试模型 软件测试模型汇总

  8. 13-部署traefik-ingress插件

    Kubernetes traefik ingress安装 Ingress简介 如果你还不了解,ingress是什么,可以先看下我翻译的Kubernetes官网上ingress的介绍Kubernetes ...

  9. [每天解决一问题系列 - 0013] 如何修改WiX Burn内置的窗口

    问题描述: 我们产品的burn安装包仅支持.net 3.5 sp1以上,在只有.net 2.0的机器上会给用户弹一个窗口,告诉用户为什么不能够安装的原因.本来burn已经内置了,但是在日文操作系统下, ...

  10. mac下nginx搭建

    首先使用brew安装nginx brew install nginx 安装完毕后,如果我们要使用nginx监听本地的80端口,需要改掉mac自带的apache占用的80端口 sudo vim /etc ...