gdb 调试多线程

基本i threads 等操做略过,只谈线程同步、异步控制:shell

先点到,gdb attach到主线程t1 时,全部线程都会中止,所谓同步异步效果,是指在apply continue到全部线程以后,app

再切换到t2,发现t3还在运行(若是t3卡在了断点上,也算运行,只不过运行后中止了)。异步

再点到,gdb 直接attach 到非主线程时,是不影响,其余线程的启停的。不管如何设置non-stop或者schedule选项。async

 

如下,重点说下non-stop和schedule选项:函数

1 non-stop测试

只能在~/.gdbinit里设置,不能在gdb运行时设置,设置内容为:线程

set target-async 1
set pagination off
set non-stop on调试

attach到主线程t1后,切换t3,ip

设置t3和t2内部的断点,执行c,t3运行后卡在断点,可是t2是不运行的,此时应t apply t2 t3(为了回到中断,只写t2会没法输入gdb操做) c,才能通知t2运行。get

若是t2无断点,那么一次t apply t2 t3后,他就是一直执行的了!

 

 

2 scheduler-locking选项

能够在主线程或者子线程设置都可。

在使用step或者continue命令调试当前被调试线程的时候,

off 不锁定任何线程,也就是全部线程都执行;若是

on 只有当前被调试程序会执行;

step 在单步的时候,除了next过一个函数的状况(熟悉状况的人可能知道,这实际上是一个设置断点而后continue的行为)之外,只有当前线程会执行。

       能够理解为step锁,非step不锁。

 

t2和t3设置断点后,设置sche为off(俩t都执行)或者on(只看到一个thr执行),直接c,就能看到t2和t3的同步或异步效果;

这时,若是t app 2 3 c,执行,效果和c同样,即便t二、t3只有一个断点,也会同时停下来的(non-stop在非断点的t不会停,除非新设b断干预之)。

 

注意:set non-stop on和scheduler-locking同时设置效果未定义,测试,设置non-stop后再设置sche=on貌似无效!

参考:

    coolshell的 gdb系列

   gdb技巧集 http://www.kancloud.cn/wizardforcel/gdb-tips-100/146771

相关文章
相关标签/搜索