使用gdb+gdbserver调试应用程序

时间:2022-05-22 21:06:07

一、gdb基本使用

​ GDB是一个由GNU开源组织发布的、UNIX/LINUX操作系统下的、基于命令行的、功能强大的程序调试工具。 对于一名Linux下工作的c++程序员,gdb是必不可少的工具;

1. 启动gdb

​ 对于C/C++程序,编译的时候需要加上 -g 参数生成调试信息。如:gcc -g hello.c -o hello

  • 调试可执行程序

    $gdb 程序名称
    $gdb ./hello  # 调试当前目录下名称为hello的程序
  • 调试服务程序

    $gdb 程序名称 进程pid
    $gdb hello  5678 # 调试当前目录下名称为hello,进程pid为5678的程序
  • 调试core文件(程序崩溃后生成的core dump 文件)

    $gdb 程序名称 core文件名称
    $gdb hello  core.0609 # 调试当前目录下名称为hello,core文件名称为core.0609的程序

2. gdb交互式命令

​ 启动gdb后,进入到交互模式,通过以下命令完成对程序的调试;高频使用的命令一般都会有缩写,熟练使用这些缩写命令能提高调试的效率;

运行

  • run:缩写为 r,运行程序,当遇到断点后停止,程序会在断点处停止运行,等待用户输入下一步的命令,类似于vs中的 F5
  • continue: 缩写为 c,继续执行,到下一个断点(没有断点就运行到程序结束)。
  • step: 缩写为 s,单步调试如果遇到函数则进入函数;与命令n不同,n是不尽然调用的函数的,step 相当于vs的 F11
  • next:缩写为 n,单步跟踪程序,当遇到调用函数时不进入函数;此命令与step的主要区别是,step 遇到用户自定义的函数,进步入到函数中运行,而 next 则是直接调用函数,不会进入到函数内,next 相当于vs的 F10
  • until: 当进入到循环中时,使用until命令可以使程序直接运行到退出循环体。
  • until+行号:运行至指定行,不仅仅用来跳出循环。
  • finish: 运行程序,知道当前函数返回,并打印函数返回时的堆栈地址和返回值及参数值等信息。
  • call 函数(参数) : 调用程序中的函数,并传递“参数”,如: call add(3,2)
  • quit: 缩写为q,退出gdb。

设置断点

gdb使用break(缩写为 b) 来设置断点,具体使用如下:

  • break n (简写 b n),在第 n 行处设置断点(可以写上代码路径和文件名称,如b ./test.cpp:10)
  • b fn1 if a>b ,设置条件断点。
  • b func ,在函数func()入口处设置断点。
  • info b (info breakpoints)显示当前程序的断点设置情况和断点的断点号等信息。
  • disable 断点号n, 禁用第n个断点。
  • enable 断点号n,启用第n个断点。
  • delete 断点号n,删除第n个断点。
  • delete breakpoints,清除所有断点。

查看源代码

  • list 简记为 l : 列出程序的源代码,默认每次显示10行。
  • list 行号:将显示当前文件以“行号”为中心的前后10行代码,如:list 12
  • list 函数名:将显示“函数名”所在函数的源代码,如:list main
  • list:不带参数,将接着上一次 list 命令的,输出下边的内容。

打印表达式

  • print 表达式:简记为 p ,其中“表达式”可以是任何当前正在被测试程序的有效表达式,比如当前正在调试C语言的程序,那么“表达式”可以是任何C语言的有效表达式,包括数字,变量甚至是函数调用。
  • print a:将显示整数 a 的值
  • print ++a:将把 a 中的值加1,并显示出来
  • print name:将显示字符串 name 的值
  • print gdb_test(22):将以整数22作为参数调用 gdb_test() 函数
  • print gdb_test(a):将以变量 a 作为参数调用 gdb_test() 函数
  • display 表达式:在单步运行时将非常有用,使用display命令设置一个表达式后,它将在每次单步进行指令后,紧接着输出被设置的表达式及值。如: display a
  • watch 表达式:设置一个监视点,一旦被监视的“表达式”的值改变,gdb将强行终止正在被调试的程序。如: watch a
  • whatis:查询变量或函数
  • info function: 查询函数
  • 扩展info locals: 显示当前堆栈页的所有变量

查询查询运行信息

  • where/bt :当前运行的堆栈列表;
  • bt backtrace 显示当前调用堆栈
  • up/down 改变堆栈显示的深度
  • set args 参数:指定运行时的参数
  • show args:查看设置好的参数
  • info program: 来查看程序的是否在运行,进程号,被暂停的原因。

分割窗口

  • layout:用于分割窗口,可以一边查看代码,一边测试:

  • layout src:显示源代码窗口

  • layout asm:显示反汇编窗口

  • layout regs:显示源代码/反汇编和CPU寄存器窗口

  • layout split:显示源代码和反汇编窗口

  • Ctrl + L:刷新窗口

二、gdb + gdbserver 实现远程调试

未完待续...