如何使用gdb观察core的时候线程表现
2023-07-14 20:29 轩脉刃 阅读(121) 评论(1) 编辑 收藏 举报如何使用gdb观察core的时候线程表现
> info thread
显示内容如下:
(gdb) info thread
Id Target Id Frame
70 Thread 0x7fe31f7fe700 (LWP 1416944) 0x00007fe4102c6945 in pthread_cond_wait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
69 Thread 0x7fe31effd700 (LWP 1416945) 0x00007fe4102c6cf2 in pthread_cond_timedwait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
68 Thread 0x7fe348ff9700 (LWP 1416936) 0x00007fe4102c6945 in pthread_cond_wait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
67 Thread 0x7fe407f28700 (LWP 1415961) 0x00007fe40f4f8fd3 in epoll_wait () from /lib64/libc.so.6
66 Thread 0x7fe3ee91f700 (LWP 1415970) 0x00007fe40f4f8fd3 in epoll_wait () from /lib64/libc.so.6
65 Thread 0x7fe30effd700 (LWP 1416949) 0x00007fe4102c6945 in pthread_cond_wait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
64 Thread 0x7fe3c99bc700 (LWP 1415988) 0x00007fe40f4bf8ed in nanosleep () from /lib64/libc.so.6
63 Thread 0x7fe30f7fe700 (LWP 1416948) 0x00007fe4102c6945 in pthread_cond_wait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
62 Thread 0x7fe30ffff700 (LWP 1416947) 0x00007fe4102c6cf2 in pthread_cond_timedwait@@GLIBC_2.3.2 ()
from /home/demo/libpthread.so.0
61 Thread 0x7fe36f7fe700 (LWP 1416917) 0x00007fe4102c3f57 in pthread_join ()
...
可以看到,这个进程启动了70个线程,gdb给每个线程进行了编号,比如线程号为 1416944 的编号为 70。
使用命令t [id]
进入到线程中(这里的id就是上面看到的线程编号),再使用命令 bt
查看core的时候线程运行堆栈。
表现如下:
(gdb) t 1
[Switching to thread 1 (Thread 0x7fe30dffb700 (LWP 1417760))]
#0 0x00007fe40f4303d7 in raise () from /lib64/libc.so.6
(gdb) bt
#0 0x00007fe40f4303d7 in raise () from /lib64/libc.so.6
#1 0x00007fe40f431ac8 in abort () from /lib64/libc.so.6
#2 0x00007fe418238155 in __gnu_cxx::__verbose_terminate_handler () at ../../../../libstdc++-v3/libsupc++/vterminate.cc:95
#3 0x00007fe418235f16 in __cxxabiv1::__terminate (handler=<optimized out>) at ../../../../libstdc++-v3/libsupc++/eh_terminate.cc:47
#4 0x00007fe418235f61 in std::terminate () at ../../../../libstdc++-v3/libsupc++/eh_terminate.cc:57
#5 0x00007fe418260e6e in std::execute_native_thread_routine (__p=0x7fe36449e590) at ../../../../../libstdc++-v3/src/c++11/thread.cc:91
#6 0x00007fe4102c2e25 in start_thread () from /home/demo/libpthread.so.0
#7 0x00007fe40f4f89fd in clone () from /lib64/libc.so.6
实时了解作者更多技术文章,技术心得,请关注微信公众号“轩脉刃的刀光剑影”
本文基于署名-非商业性使用 3.0许可协议发布,欢迎转载,演绎,但是必须保留本文的署名叶剑峰(包含链接http://www.cnblogs.com/yjf512/),且不得用于商业目的。如您有任何疑问或者授权方面的协商,请与我联系。