基本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