• <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>
            Lyt
            posts - 16,comments - 61,trackbacks - 0

             內(nèi)存泄漏是編程中常常見到的一個(gè)問題,我所遇過的原因有兩個(gè):

            1.分配完內(nèi)存后忘記回收

            2.代碼有問題,造成想回收卻無法回收,例如:

            int* p=new int;
            p
            =new int;   //p指針修改,原來申請(qǐng)內(nèi)存的地址沒有記錄下來,于是無法釋放

             下面介紹如何檢查內(nèi)存泄漏:

            1.包含頭文件和定義

            #define _CRTDBG_MAP_ALLOC   //并非絕對(duì)需要該語句,但如果有該語句,打印出來的是文件名和行數(shù)等更加直觀的信息
            #include 
            <stdlib.h>
            #include 
            <crtdbg.h>

            (1)#include語句必須采用上文所示順序。如果更改了順序,所使用的函數(shù)可能無法正確工作

            (2)如果有cpp文件無法看到這三行,以下函數(shù)就無效了,于是應(yīng)該把這三行放到一個(gè)頭文件里,確保每個(gè)cpp文件會(huì)調(diào)用到它

            2.方法一:使用_CrtDumpMemoryLeaks()

            int main(int argc , char* argv[])
            {
                {
            new int;}
                _CrtDumpMemoryLeaks();
                
            return 0;
            }

            output:

            Detected memory leaks!
            Dumping objects ->
            {49} normal block at 0x00384DA8, 4 bytes long.
             Data: <    > CD CD CD CD
            Object dump complete.

            其內(nèi)容包括:內(nèi)存分配型號(hào)(在大括號(hào)內(nèi))、塊類型(普通、客戶端或 CRT)、 十六進(jìn)制形式的內(nèi)存位置、以字節(jié)為單位的塊大小、以字節(jié)為單位的塊大小、前 16 字節(jié)的內(nèi)容(十六進(jìn)制)

            注意:

            (1)大括號(hào)的位置,如果不加{new int;},這塊內(nèi)存是等到main函數(shù)結(jié)束才泄漏的,而_CrtDumpMemoryLeaks()是在main函數(shù)里調(diào)用的,于是判斷內(nèi)存泄漏

            class A
            {
            public:
                
            int* Data;
                A()
                {
                    Data
            =new int;
                }
                
            ~A()
                {
                    delete Data;
                }
            };

            int main(int argc , char* argv[])
            {
                A Test;
                _CrtDumpMemoryLeaks();
                
            return 0;
            }

            output:

            Detected memory leaks!
            Dumping objects ->
            {49} normal block at 0x00384DA8, 4 bytes long.
             Data: <    > CD CD CD CD
            Object dump complete.

            (2)對(duì)于一些全局函數(shù),如果初始化時(shí)申請(qǐng)了內(nèi)存,到程序結(jié)束時(shí)候才釋放,此函數(shù)會(huì)一直把新申請(qǐng)的內(nèi)存當(dāng)作泄漏來對(duì)待

            A Test;
            int main(int argc , char* argv[])
            {
                _CrtDumpMemoryLeaks();
                
            return 0;
            }

            output:

            Dumping objects ->
            {49} normal block at 0x00384DA8, 4 bytes long.
             Data: <    > CD CD CD CD
            Object dump complete.

            2.方法二:在程序入口寫幾個(gè)語句,程序退出時(shí),如果發(fā)現(xiàn)有內(nèi)存泄漏,會(huì)自動(dòng)在DEBUG OUTPUT窗口和DebugView中輸出內(nèi)存泄漏信息

            int tmpFlag = _CrtSetDbgFlag( _CRTDBG_REPORT_FLAG );
             tmpFlag 
            |= _CRTDBG_LEAK_CHECK_DF;
             _CrtSetDbgFlag( tmpFlag );

            3.方法三:使用_CrtMemCheckpoint(),可以查出某程序段的內(nèi)存泄漏情況

            int main(int argc , char* argv[])
            {
                CrtMemState s1, s2, s3;
                _CrtMemCheckpoint( 
            &s1 );
                
            new int//程序段
                _CrtMemCheckpoint( &s2 );
                
            if ( _CrtMemDifference( &s3, &s1, &s2) ) _CrtMemDumpStatistics( &s3 );
                
            return 0;
            }

            output:

             bytes in 0 Free Blocks.
            4 bytes in 1 Normal Blocks.
            0 bytes in 0 CRT Blocks.
            0 bytes in 0 Ignore Blocks.
            0 bytes in 0 Client Blocks.
            Largest number used: 0 bytes.
            Total allocations: 4 bytes.

            posted on 2009-03-22 23:45 Lyt 閱讀(18416) 評(píng)論(4)  編輯 收藏 引用 所屬分類: 其他

            FeedBack:
            # re: 如何檢查C++中的內(nèi)存泄漏
            2009-03-23 09:18 | wulin
            age=上げ
              回復(fù)  更多評(píng)論
              
            # re: 如何檢查C++中的內(nèi)存泄漏[未登錄]
            2009-03-23 09:29 | Aladdina
            如果是使用Visual C++的話,可以把Visual Leak Detector加入你的工程。  回復(fù)  更多評(píng)論
              
            # re: 如何檢查C++中的內(nèi)存泄漏
            2009-03-23 16:50 | Sunshine Alike
            有機(jī)會(huì)try一下,學(xué)習(xí)了  回復(fù)  更多評(píng)論
              
            # re: 如何檢查C++中的內(nèi)存泄漏
            2009-04-16 10:30 | yindf
            有沒有辦法解決使用Visual Leak Detector以后,運(yùn)行速度奇慢無比的問題呀?  回復(fù)  更多評(píng)論
              
            欧美黑人激情性久久| 94久久国产乱子伦精品免费| 久久国产美女免费观看精品| 亚洲国产精品久久久久| 国产精品女同一区二区久久| 理论片午午伦夜理片久久 | 亚洲综合精品香蕉久久网97 | 国产毛片久久久久久国产毛片| 久久精品国产精品亚洲人人| 久久妇女高潮几次MBA| 中文字幕久久久久人妻| 青青草原综合久久| 精品人妻伦九区久久AAA片69 | 久久综合九色综合网站| 国产日产久久高清欧美一区| yy6080久久| 久久久久免费视频| 色综合久久中文色婷婷| 久久99精品久久久大学生| 国产高清美女一级a毛片久久w| 波多野结衣AV无码久久一区| 久久99精品久久久久久9蜜桃 | 久久香综合精品久久伊人| 伊人久久大香线焦综合四虎| 欧美黑人又粗又大久久久| 噜噜噜色噜噜噜久久| 精品99久久aaa一级毛片| 久久精品国产亚洲综合色| 中文字幕久久波多野结衣av| 亚洲人成电影网站久久| 久久人人爽人人精品视频| 久久免费大片| 99热热久久这里只有精品68| 久久99精品久久久久久久不卡| 97久久婷婷五月综合色d啪蜜芽| 亚洲国产成人久久精品99| 无码任你躁久久久久久久| 精品无码人妻久久久久久| 国产成人精品久久亚洲| 久久久久一级精品亚洲国产成人综合AV区| 亚洲午夜久久影院|