GDB调试
1,使用bt(backtrace )命令查看当前堆栈
(gdb) bt #0 muduo::Poller::poll (this=0x62e010, timeoutMs=10000, activeChannels=0x7fffffffe3c0) at Poller.cc:31 #1 0x0000000000403f60 in muduo::EventLoop::loop (this=0x7fffffffe390) at EventLoop.cc:80 #2 0x0000000000402876 in main () at test8.cc:41
#0:是当前执行的函数(栈帧)(fram)
2,使用f(frame)命令:查看当前frame(函数,栈帧)里的变量值等信息
3,使用f(frame) n:查看某一个frame(函数,栈帧)里的变量值等信息
n是bt命令返回的数字,标识出是哪一个frame
4,使用up/down命令,向上或向下移动栈帧
down n
:表示往栈顶方向下移 n 层 (n 表示一个正整数,默认值为 1)up n
:命令表示往栈底方向上移 n 层 (类似地,up
表示往栈底方向上移 1 层)。
注意:在虚拟内存地址空间中,栈是从高往低扩展的
5,info命令
info args
:打印出当前函数的参数名称和值info locals
:打印出当前函数里所以的局部变量的名字和值info catch
:打印出当前函数中的异常处理信息 。
6. info threads
显示当前可调试的所有线程,每个线程会有一个GDB为其分配的ID,后面操作线程的时候会用到这个ID。
前面有*的是当前调试的线程。
thread ID
切换当前调试的线程为指定ID的线程
7.gdb调试输入参数
假设数据在input.txt当中, 可执行文件名为myprogram。
$ cat input.txt this is a test. $ gdb myprogram // 启动调试 (gdb) break // 设置断点 run arg1 arg2 ... < input.txt // 传入参数,以及输入数据 n or s //单步调试,n不进入函数,s进入函数 p variable_name //打印变量值 c // 执行至下一断点
如果使用cmake来自动生成Makefile,如何加入调试信息?
设置选项-DCMAKE_BUILD_TYPE=Debug
8.断点
根据行数进行断点:
(gdb) b src/main.cpp:127
条件断点:
(gdb) b src/main.cpp:127 if cnt==1
函数断点:
(gdb) b funcName
设置监视也必须是在程序运行后才行。如:
(gdb) watch *地址 # 当地址所指内容发送变化时断点
(gdb) watch var #当var值变化时,断点
(gdb) watch (condition) #当条件符合时,断点
9.