<menu id="w8yyk"><menu id="w8yyk"></menu></menu>
  • <dd id="w8yyk"><nav id="w8yyk"></nav></dd>
    <menu id="w8yyk"></menu>
    <menu id="w8yyk"><code id="w8yyk"></code></menu>
    <menu id="w8yyk"></menu>
    <xmp id="w8yyk">
    <xmp id="w8yyk"><nav id="w8yyk"></nav>
  • 網站首頁 > 物聯資訊 > 技術分享

    gdb 調試多線程 神貼

    2016-09-28 00:00:00 廣州睿豐德信息科技有限公司 閱讀
    睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接

    gdb 調試多線程
    如果目標進程已經core dump了,那么 gdb -c core xxx   xxx是對應的程序文件。
    如果目標進程還在運行,通常此時用于調試線程死鎖的情況。有兩種方法
    一是 gdb -p xxx  xxx是該進程的進程ID
    或者用gcore xxx先獲取對應進程的core,他會生成一個core文件 core.xxx
     
    進入gdb后
    (gdb) info threads
    可以列出所有的線程,缺省設為當前的線程前面有一個*號
    比如
    gdb) info thread
        9 system thread 154262  Priority:154  0xc00000000042f670:0 in __ksleep
       +0x30 () from /usr/lib/hpux64/libc.so.1
        4 system thread 153674  Priority:168  0xc0000000004367d0:0 in _nanosleep2_sys+0x30 () from /usr/lib/hpux64/libc.so.1
        3 system thread 153673  Priority:168  0xc0000000004367d0:0 in _nanosleep2_sys+0x30 () from /usr/lib/hpux64/libc.so.1
        2 system thread 153672  Priority:154  0xc00000000042f670:0 in __ksleep
       +0x30 () from /usr/lib/hpux64/libc.so.1
    *   1 system thread 153671  Priority:154  0xc000000000432ef0:0 in _read_sys
       +0x30 () from /usr/lib/hpux64/libc.so.1
     
    這是1個死鎖的例子,可以看到線程9 和線程2都停在 __ksleep上。
    如果想看各個線程的詳細堆棧信息,比如要看9的
    gdb)thread 9
    把當前線程設成9,然后就可以查看相關信息
    比如
    gdb)bt
    將列出棧的調用情況,以及對應源代碼中的位置,此時謹慎察看對應代碼,一般必有結果
    http://blog.sina.com.cn/s/blog_62dc94eb0100flyn.html

    RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成
    最近免费观看高清韩国日本大全