gdb调试
gdb调试的是可执行文件,在gcc编译时加入-g ,告诉gcc在编译时加入调试信息,这样gdb才能调试这个被编译的文件gcc -g tesst.c -o test
bt查看程序调用的栈
进程调试
调试父进程: set follow-fork-mode parent(缺省)
调试子进程: set follow-fork-mode child
设置调试模式: set detach-on-fork [onloff],缺省是on,表示调试当前进程的时,其它进程继续运行,如果用off,调试当前进程的时,其它的进程被gdb挂起。
查看调试的进程: info inferiors
切换当前调试的进程: inferior 进程id
线程调试
查看线程: info threads
切换线程: thread 线程id
只运行当前线程: set scheduler-locking on
运行全部的线程: set scheduler-locking off
指定某线程执行某gdb命令: thread apply线程id cmd
全部的线程执行某gdb命令: thread apply all cmd
设置断点或单步跟踪可能会严重干扰多进(线)程之间的竞争状态。导致我们看到的是一个假象。设置断点或单步跟踪可能会严重干扰多进(线)程之间的竞争状态.导致我们看到的是一个假象.
因此可以通过在终端打印或打印日志的方法来实现。
程序挂掉时,系统缺省不会生成core文件。
1 ) ulimit -a查看系统参数;
2 ) ulimit -c unlimit 把core文件的大小设为无限制;
3 ) 运行程序,生成core文件;
4 )gdb程序名core文件名。
其他
在shell中执行:
查看当前运行的进程: ps aux | grep book
查看当前运行的轻量级进程: ps -aL | grep book
查看主线程和子线程的关系: pstree -p主线程id
参考
https://www.bilibili.com/video/BV1ei4y1V758/?spm_id_from=333.337.search-card.all.click&vd_source=07c19be7e433a8cd75d9808899f4c9d9