• <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 閱讀(18418) 評(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)論
              
            国产成人久久激情91| 国产精品99久久99久久久| 亚洲国产成人精品91久久久 | 久久国产精品久久久| 成人久久精品一区二区三区| 一本伊大人香蕉久久网手机| 2019久久久高清456| 久久夜色精品国产噜噜噜亚洲AV| 久久精品国产69国产精品亚洲| 久久综合狠狠综合久久激情 | 精品熟女少妇a∨免费久久| 国产精品一久久香蕉国产线看| 久久亚洲2019中文字幕| 99久久人妻无码精品系列| 一本久久精品一区二区| 久久免费小视频| 久久Av无码精品人妻系列| 亚洲人成无码www久久久| 国产福利电影一区二区三区久久久久成人精品综合 | 久久天天躁狠狠躁夜夜躁2014| 国产精品免费久久| 久久人人爽人人爽人人AV东京热| 狠狠色伊人久久精品综合网 | 亚洲&#228;v永久无码精品天堂久久 | 国产精品99久久久精品无码| 青青青国产成人久久111网站| 久久精品国产色蜜蜜麻豆| 久久久久无码中| 久久国产精品国语对白| 青草影院天堂男人久久| 久久ZYZ资源站无码中文动漫| 狠狠色丁香久久婷婷综合| 国内精品伊人久久久久妇| 久久影视综合亚洲| 亚洲精品无码久久不卡| 亚洲国产精品嫩草影院久久| 人妻系列无码专区久久五月天| 久久久久这里只有精品| 精品久久久久久久久久中文字幕 | 久久天天躁狠狠躁夜夜2020| 久久国产成人午夜aⅴ影院|