简单总结常用gdb调试命令
不长篇讨论gdb是什么,或者怎么使用了,因为网上很多都讲的比较详细,以下只是做个备录,经常使用的命令,偶尔不用容易忘记!
1.set args xxxx (xxx为参数)
2.r (run 运行程序)
3.n (next
是在单步执行时,在函数内遇到子函数时不会进入子函数内单步执行,而是将子函数整个执行完再停止,也就是把子函数整个作为一步)
4.s (step 同样是单步执行,但是遇到子函数就进入并且继续单步执行)
5.finish (当s进入某个函数调试,finish就是结束该函数,继续调试)
5.b (break point打断点,如:b main 即在main主函数打了一个断点)
6.d (delete 删除某个断点,如:d 1 删除第一个断点或者delete 1意思一样)
7.p (print 打印,如:p a 即打印a的值,前面可以加上如/x 、/u、/f、等, => p /x a即打印的是16进制等等)
8.p &a (打印a的地址)
9.c (continue) 执行到下一个断点或程序结束
10.info threads 查看当前线程调试信息
11.bt (backtrace) 查看所有调用栈信息
12.info breakpoints 查看断点处信息(info 查看信息 info 查看帮助可以看到还有很多命令)
13. i locals 显示所有当前调用栈的所有变量
14.x (examine 检查,如x/3uh 0x58090A9C,就是打印地址 0x58090A9C,3个单位双字节无符号数,3代表3个单位,u代表无符号数,h代表以双字节为一个单位) 检查某一个地址附近内容
15.disassemble 查看当前函数汇编信息(如:disassemble /rm /m指示显示汇编指令的同时,显示相应的程序源码;/r指示显示十六进制的计算机指令(raw instruction))
设置core环境
ulimit -a 查看默认参数
ulimit -c 查看core dump文件是否打开,如果显示为0,则没有打开,显示为unlimited,则代表core dump 文件打开了
ulimit -c 1024 设置core文件大小为1024
ulimit -c unlimited 打开系统开关,让其可以在程序crash的时候生成core文件。多线程如果dump,多为段错误,一般都涉及内存非法读写。
ulimit -c 0 关闭core dump系统开关
假设生成core dump文件为core.11493,调试直接为gdb + 进程名+ core.11493,其它和gdb调试步骤一样