青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

elva

Linux下,多線程程序死循環(huán)問題調(diào)試

當你的軟件在某個時刻停止服務(wù),CPU占用達到100%+,這種問題一個可能的原因是產(chǎn)生了死循環(huán),假設(shè)程序某處存在潛在的死循環(huán),并在某種條件下會引發(fā),本文以一個示例來定位出現(xiàn)死循環(huán)的位置。
當程序某處存在死循環(huán),通常定位問題及縮小范圍的方法是,在可疑的代碼處加log,或者注釋掉可疑代碼,這對于容易重現(xiàn)問題的程序來說還好,但對于“偶爾”才會產(chǎn)生問題程序卻很難調(diào)試,因為我們很難重現(xiàn)程序故障。本文所述的調(diào)試過程正是在這種情況下,假設(shè)問題已經(jīng)出現(xiàn),我們要求環(huán)境保護現(xiàn)場,即出問題的程序還在運行中。

1.我們首先要知道是哪個線程出了問題:
首先查一下出問題進程的pid,例如
ovtsvn@ovtsvn:~/MASS4/src/icdn/src$ ps -ef | grep icdn
ovtsvn   
11065     1 50 11:57 ?        00:00:07 ./icdn
ovtsvn   
11076 10971  0 11:57 pts/2    00:00:00 grep icdn
ovtsvn@ovtsvn:
~/MASS4/src/icdn/src$ 
然后top命令查看線程信息:
top -H -p 11065

  PID USER      PR  NI  VIRT  RES  SHR S 
%CPU %MEM    TIME+  COMMAND                                                                
11073 ovtsvn    25   0  325m 3980 2236 R  100  0.4   1:40.84 icdn                                                                   
11065 ovtsvn    18   0  325m 3980 2236 S    0  0.4   0:00.01 icdn                                                                   
11066 ovtsvn    18   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11067 ovtsvn    15   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11068 ovtsvn    15   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11069 ovtsvn    18   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11070 ovtsvn    18   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11071 ovtsvn    22   0  325m 3980 2236 S    0  0.4   0:00.00 icdn                                                                   
11072 ovtsvn    15   0  325m 3980 2236 R    0  0.4   0:00.00 icdn
從上面可以看出,出問題線程PID為11073

2.接下來,我們用gdb來attach目標進程
執(zhí)行: gdb icdn 11065
在gdb中,列出線程狀態(tài):
(gdb) info threads
  
9 Thread 47056948181264 (LWP 11066)  0x00002acc4a3dec91 in nanosleep () from /lib/libc.so.6
  
8 Thread 47056956573968 (LWP 11067)  0x00002acc4a406fc2 in select () from /lib/libc.so.6
  
7 Thread 47056964966672 (LWP 11068)  0x00002acc4a3dec91 in nanosleep () from /lib/libc.so.6
  
6 Thread 47056973359376 (LWP 11069)  0x00002acc4a3dec91 in nanosleep () from /lib/libc.so.6
  
5 Thread 47056981752080 (LWP 11070)  0x00002acc4a3dec91 in nanosleep () from /lib/libc.so.6
  
4 Thread 47056990144784 (LWP 11071)  0x00002acc4a40e63c in recvfrom () from /lib/libc.so.6
  
3 Thread 47057194060048 (LWP 11072)  0x00002acc4a406fc2 in select () from /lib/libc.so.6
  
2 Thread 47057226893584 (LWP 11073)  CSendFile::SendFile (this=0x2acc5d4aff40, pathname=@0x2acc5d4afee0)
    at ..
/src/csendfile.cpp:101
  
1 Thread 47056939784832 (LWP 11065)  0x00002acc4a3dec91 in nanosleep () from /lib/libc.so.6
(gdb) 

gdb已經(jīng)列出了各線程正在執(zhí)行的函數(shù),我們需要更多信息,記住11073對應(yīng)的行首標號,這是gdb為線程分配的id,這里為2,然后執(zhí)行切換:
(gdb) thread 2
[Switching to thread 
2 (Thread 47057226893584 (LWP 11073))]#0  CSendFile::SendFile (this=0x2acc5d4aff40, pathname=@0x2acc5d4afee0)
    at ..
/src/csendfile.cpp:101
101             while(1)
(gdb) 


bt一下:
(gdb) bt
#
0  CSendFile::SendFile (this=0x2acc5d4aff40, pathname=@0x2acc5d4afee0) at ../src/csendfile.cpp:101
#
1  0x000000000040592e in CIcdn::TaskThread (pParam=0x7fff617eafe0) at ../src/cicdn.cpp:128
#
2  0x00002acc4a90b73a in start_thread () from /lib/libpthread.so.0
#
3  0x00002acc4a40d6dd in clone () from /lib/libc.so.6
#
4  0x0000000000000000 in ?? ()

來看一下101行的代碼:
(gdb) l
96      }
97
98      int CSendFile::SendFile(const string& pathname)
99      {
100             int n;
101             while(1)
102             {
103                     n++;
104             }

105             //read file and send 


現(xiàn)在我們定位到了出問題的代碼位置,這里的循環(huán)只用來演示的。
最后別忘了detach

posted on 2010-08-02 12:08 葉子 閱讀(7520) 評論(2)  編輯 收藏 引用 所屬分類: C\C++

Feedback

# re: Linux下,多線程程序死循環(huán)問題調(diào)試 2010-08-02 12:11 yugi

不錯  回復(fù)  更多評論   

# re: Linux下,多線程程序死循環(huán)問題調(diào)試 2010-08-02 12:50 Tanky Woo

呵呵,學(xué)習(xí)了。  回復(fù)  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久精品99无色码中文字幕 | 国产视频在线观看一区二区三区| 久久久噜噜噜久噜久久| 亚洲伊人久久综合| 亚洲在线不卡| 欧美一级夜夜爽| 久久精品一区二区国产| 久久激五月天综合精品| 牛人盗摄一区二区三区视频| 欧美精品性视频| 国产精品扒开腿做爽爽爽视频| 国产精品大片wwwwww| 国产美女精品在线| 激情视频一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆| 日韩午夜在线视频| 欧美成人资源| 国产精品视频午夜| 今天的高清视频免费播放成人 | 欧美大香线蕉线伊人久久国产精品| 欧美a级大片| 亚洲精品一区二区三区不| 午夜精品视频网站| 欧美激情第三页| 国产一区二区三区日韩| 99精品视频网| 欧美3dxxxxhd| 亚洲欧美怡红院| 欧美日韩精品三区| 亚洲国产网站| 久久香蕉精品| 亚洲一区二区成人| 欧美精品成人91久久久久久久| 国产日韩欧美日韩大片| 99re这里只有精品6| 看片网站欧美日韩| 亚洲欧美日韩区| 欧美丝袜一区二区三区| 亚洲高清av| 久久久久网址| 性色av一区二区三区| 国产精品www色诱视频| 亚洲精品一区二| 欧美激情一区二区三区| 欧美在线你懂的| 国产日韩精品在线| 亚洲综合国产精品| 日韩视频一区二区| 欧美风情在线| 亚洲人成在线观看网站高清| 久久久久在线观看| 午夜精品成人在线| 国产精品嫩草99av在线| 亚洲视频一起| 日韩午夜一区| 欧美日韩四区| 亚洲一级免费视频| 夜色激情一区二区| 欧美涩涩网站| 一本大道av伊人久久综合| 欧美国产一区二区在线观看| 久久午夜精品一区二区| 国产一区二区精品久久91| 久久gogo国模裸体人体| 亚洲欧美日韩一区在线| 国产香蕉久久精品综合网| 亚洲中字黄色| 亚洲男人的天堂在线观看| 国产精品日韩在线一区| 亚洲欧美在线视频观看| 亚洲欧美一区二区三区极速播放| 欧美性做爰毛片| 篠田优中文在线播放第一区| 久久视频免费观看| 久久精品日韩欧美| 最新成人av在线| 一本大道久久a久久综合婷婷| 国产精品国产精品国产专区不蜜| 亚洲一区二区精品| 亚洲欧美国产制服动漫| 国产亚洲美州欧州综合国| 久久久免费精品| 欧美jizz19性欧美| 宅男精品视频| 欧美一区二区性| 亚洲高清一区二| 日韩午夜剧场| 国产一区自拍视频| 亚洲高清在线播放| 欧美伦理在线观看| 久久久精品国产一区二区三区 | 一本大道av伊人久久综合| 日韩系列欧美系列| 好看的av在线不卡观看| 亚洲精品美女在线| 国产日韩欧美在线观看| 欧美国产亚洲视频| 国产日产欧产精品推荐色| 亚洲高清不卡在线| 国产一区91| 99综合视频| 极品少妇一区二区三区| 一本色道久久88综合亚洲精品ⅰ| 国产视频亚洲精品| 亚洲国产精品小视频| 国产日韩欧美在线看| 亚洲激情一区二区| 在线观看中文字幕不卡| 亚洲欧美激情视频| 亚洲夜间福利| 欧美激情亚洲国产| 久久香蕉精品| 国产精品亚洲аv天堂网 | 午夜精品久久久久久久99樱桃 | 午夜精品久久久久久久| 久久精品国产免费观看| 亚洲午夜精品一区二区| 久久蜜臀精品av| 欧美亚洲视频| 欧美日韩一区二区视频在线观看| 欧美jizz19hd性欧美| 国产一本一道久久香蕉| 在线亚洲激情| av成人动漫| 欧美成人精品高清在线播放| 久久精品麻豆| 国产精品视频福利| 亚洲一区二区欧美日韩| 在线综合亚洲| 欧美日韩国产综合视频在线| 欧美国产日韩xxxxx| 久久精品99无色码中文字幕| 欧美一级大片在线观看| 欧美日韩精品久久久| 亚洲国产精品久久91精品| 亚洲国产日韩在线| 麻豆亚洲精品| 久久久精品久久久久| 久久久中精品2020中文| 国产视频久久久久| 午夜久久福利| 久久精品一区二区三区四区| 国产亚洲精品久久久久动| 香蕉乱码成人久久天堂爱免费| 性欧美video另类hd性玩具| 国产麻豆精品久久一二三| 午夜欧美大片免费观看| 久久久久久欧美| 在线免费观看视频一区| 久久综合免费视频影院| 亚洲电影激情视频网站| 亚洲美女在线观看| 欧美精品啪啪| 亚洲一线二线三线久久久| 久久精品亚洲国产奇米99| 国产午夜亚洲精品理论片色戒| 久久国产一二区| 亚洲国产精品一区二区第四页av| 一区二区三区毛片| 国产精品一二一区| 久久免费视频在线| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲视频欧洲视频| 国产亚洲毛片在线| 女人天堂亚洲aⅴ在线观看| 亚洲精品字幕| 久久免费一区| 亚洲婷婷综合久久一本伊一区| 国产精品日日摸夜夜添夜夜av| 欧美一区日韩一区| 亚洲精品久久久久久久久| 欧美怡红院视频| 亚洲毛片av在线| 国产精品视频一二三| 久热国产精品| 亚洲欧美中文日韩在线| 欧美激情在线播放| 久久精品综合网| 99精品国产热久久91蜜凸| 国产精品a久久久久| 久久久综合激的五月天| 亚洲午夜电影网| 欧美国产日本在线| 久久成人免费电影| 中文欧美日韩| 激情综合中文娱乐网| 欧美日韩激情小视频| 久久精品免费播放| 亚洲网站在线播放| 亚洲国产99| 久久米奇亚洲| 午夜视频一区在线观看| 亚洲人成网站999久久久综合| 国产日韩欧美一二三区| 欧美午夜精品一区| 欧美日韩国产综合网 | 国产农村妇女精品一二区| 欧美区二区三区| 老司机精品视频网站| 欧美一级在线亚洲天堂|