• <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>
            posts - 297,  comments - 15,  trackbacks - 0

            昨天解決了一個隱蔽的內存泄漏問題,原因是pthread_create后的僵死線程沒有釋放導致的內存持續增長。
            現象是這樣的:短時間內程序運行正常,但跑了12小時左右,用top查看其內存占用居然高達2G,于是馬上意識到有內存泄漏。

            最先想到的是malloc/free、new/delete沒有配對,申請的內存沒有釋放。于是寫了個跟蹤malloc/free調用的模塊,不過檢查中并沒有找到未釋放的內存。之后懷疑是不是 free then malloc 導致的內存管理錯誤(事實證明雖然free后不是立即回收內存,但是接連調用free & malloc并不會影響操作系統的內存管理),不過寫了個小程序發現并不是這么回事。

            陷入窘境了,只好用最小系統法把功能部分和內存分配都給屏蔽掉,這時發現內存泄漏依然存在!仔細看top的輸出,幾乎是每次創建線程時內存就往上漲一點,只是增長速度不是很快,看來是線程的問題了。仔細分析發現,之前圖簡單 pthread_create (&thread, NULL, &thread_function, NULL); 就這么寫了,參數2沒有設置線程結束后自動detach,并且沒有使用pthread_join或pthread_detach釋放執行結束后線程的空間!

             

            Linux man page 里有已經說明了這個問題:
                When a joinable thread terminates, its memory resources (thread descriptor and stack) are not deallocated until another thread performs pthread_join on it. Therefore, pthread_join must be called  once  for each joinable thread created to avoid memory leaks.

            也就說線程執行完后如果不join的話,線程的資源會一直得不到釋放而導致內存泄漏!一時的圖快后患無窮啊。

             

            解決辦法

            代碼
             1 // 最簡單的辦法,在線程執行結束后調用pthread_detach讓他自己釋放
             2 pthread_detach(pthread_self());
             3 
             4 
             5 // 或者創建線程前設置 PTHREAD_CREATE_DETACHED 屬性
             6 pthread_attr_t attr;
             7 pthread_t thread;
             8 pthread_attr_init (&attr);
             9 pthread_attr_setdetachstate (&attrPTHREAD_CREATE_DETACHED);
            10 pthread_create (&thread, &attr&thread_function, NULL);
            11 pthread_attr_destroy (&attr);

             

            第2行的那種方法最簡單,在線程函數尾部加上這句話就可以將線程所占用的資源給釋放掉;或者像 5-11 所示的方法設置detach屬性,這樣也會在線程return/pthread_exit后釋放內存。

            其實仔細想想,valgrind檢查時已經提示了pthread_create沒有釋放的問題,只是之前沒引起注意。其實這樣的問題也只有在長時間運行時,慢慢積累這一點點的內存才會暴露出來,看來valgrind的提示也不能置之不理啊。

            from:

            http://www.cnblogs.com/bits/archive/2009/12/04/no_join_or_detach_memory_leak.html

            posted on 2010-01-14 16:40 chatler 閱讀(3118) 評論(2)  編輯 收藏 引用 所屬分類: Linux_Coding

            FeedBack:
            # re: 解決Linux pthread_create內存泄漏問題[未登錄]
            2010-06-02 17:08 | jack
            不錯,支持一個。  回復  更多評論
              
            # re: 解決Linux pthread_create內存泄漏問題
            2012-05-03 10:07 | 朱先生
            我試過,每一種方法有的時候不行。
            第二種是可以的。
              回復  更多評論
              
            <2009年9月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            常用鏈接

            留言簿(10)

            隨筆分類(307)

            隨筆檔案(297)

            algorithm

            Books_Free_Online

            C++

            database

            Linux

            Linux shell

            linux socket

            misce

            • cloudward
            • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

            network

            OSS

            • Google Android
            • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
            • os161 file list

            overall

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品国产福利国产秒| 99久久国产综合精品麻豆| 日本免费久久久久久久网站| 久久精品人人做人人爽电影蜜月| 亚洲性久久久影院| 久久精品九九亚洲精品| 精品综合久久久久久88小说| 人妻无码精品久久亚瑟影视| 亚洲国产精品高清久久久 | 亚洲精品99久久久久中文字幕| 久久99精品九九九久久婷婷| 99久久精品免费看国产免费| 亚洲国产成人久久一区久久| A级毛片无码久久精品免费| 99久久中文字幕| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久午夜电影网| 国产成人精品久久| 久久涩综合| 久久综合给久久狠狠97色| 精品久久一区二区三区| 国产成人综合久久精品尤物| 狠狠综合久久AV一区二区三区| 国产精品久久久久无码av| 久久久久亚洲精品天堂久久久久久| 韩国三级中文字幕hd久久精品| 亚洲AV无码成人网站久久精品大| 亚洲国产精品人久久| 久久AV无码精品人妻糸列| 97久久精品人妻人人搡人人玩| 97久久婷婷五月综合色d啪蜜芽| 久久精品夜色噜噜亚洲A∨| 99999久久久久久亚洲| 亚洲欧美日韩中文久久| 久久精品中文无码资源站| 亚洲婷婷国产精品电影人久久| 日本加勒比久久精品| 亚洲AV伊人久久青青草原| 2021国内精品久久久久久影院| 亚洲午夜精品久久久久久浪潮| 18禁黄久久久AAA片|