1、编译生成执行文件:(Linux下)gcc -g tst.c -o tst
2、使用gdb调试:gdb tst
3、单进程、单线程基础调试命令:
(1)l:相当于list,从第一行开始例出源码
list filename:num——显示filename文件num行上下的源代码
(2)b/break linnum:给指定行添加断点
b/break funname:给指定函数的第一有效行添加一个断点
(3)info break:显示断点信息
(4)delete 断点号:删除指定断点
(5)r:run命令简写,运行程序
(6)n:next命令简写,单条语句执行
(7)c:continue命令简写,继续运行程序,直到执行到下一断点处
(8)p val:print命令简写,打印变量val的值
p &val:打印变量val的地址
p a+b:打印表达式的值
p arr(数组名):打印数组所有元素的值
p *parr@len:同指向数组的指针打印数组所有元素的值
(9)bt:查看函数堆栈
(10)finish:退出函数
(11)q:退出调试
(12)disable 断点号:将断点设定为无效的,如果不加断点号,将所有断点设置为无效
enable 断点号:将断点设定为有效的,如果不加断点号,将所有断点设置为有效
(13)display:自动显示,参数和p命令一样
(14)info display:显示自动显示信息
(15)undisplay + 自动显示编号:删除指定的自动显示
(16)ptype val:显示变量类型
4、多进程调试命令:
set follow-fork-mode child:设置跟踪子进程
parent:设置跟踪父进程
5、多线程调试命令:
(1)info threads:显示当前可以调试的线程信息
(2)thread id:切换到指定线路
(3)set scheduler-locking [off | on | step]
off不锁定,所有线程都可以执行
on锁定,只有当前调试线程执行
step:只有当前程序单步执行,其他线程不执行
(4)程序发生死锁怎样调试,怎样发现线程死锁。
产生死锁的四个必要条件
(a) 互斥条件:一个资源每次只能被一个进程(线程)使用。
(b) 请求与保持条件:一个进程(线程)因请求资源而阻塞时,对已获得的资源保持不放。
(c) 不剥夺条件 : 此进程(线程)已获得的资源,在末使用完之前,不能强行剥夺。
(d) 循环等待条件 : 多个进程(线程)之间形成一种头尾相接的循环等待资源关系
编译:gcc -g -o deadlock deadlock.c -lpthread
运行可执行文件,直到出现死锁情况
如下命令进行调试:
①. ps aux | grep deadlock:找到该进程号
②. gdb deadlock PID: 进入进程调试
③. generate-core-file:查看线程前,保存core文件
④. info threads: 查看所有线程
⑤. thread 2: 选择进入第二个线程
⑥. bt: 查看该线程调用的堆栈信息