• <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>

            隨心動

            (轉(zhuǎn))(轉(zhuǎn))如何調(diào)試MFC的內(nèi)存泄露

            VC++ IDE 的默認狀態(tài)(VC6)是沒有啟用內(nèi)存泄漏檢測機制的,也就是說即使某段代碼有內(nèi)存泄漏,調(diào)試會話的 Output 窗口的 Debug 頁不會輸出有關(guān)內(nèi)存泄漏信息。你必須設(shè)定以啟用內(nèi)存泄漏檢測機制。


             
            按下面的方法使用調(diào)試堆函數(shù)
            在XXXView.cpp中添加下面粗體行

            你再看看輸出結(jié)果,是不是有很多的內(nèi)存泄漏?

            #define _CRTDBG_MAP_ALLOC
            #include<stdlib.h>
            #include<crtdbg.h>


            CXXXView::~CXXXView()
            {
                 _CrtDumpMemoryLeaks();
            }

            文章出處:DIY部落(http://www.diybl.com/course/3_program/c++/cppjs/2007925/73624.html)

                   首先,應(yīng)該是MFC報告我們發(fā)現(xiàn)內(nèi)存泄漏。注意:要多運行幾次,以確定輸出的內(nèi)容不變,特別是{}之間的數(shù)值,不能變,否則下面的方法就不好用了。
            image001.jpg

                    我們來看看:

            F:\CodeSample\Test\TestPipe\LeakTest\MainFrm.cpp( 54 { 86 normal block at  0x00422E80 10  bytes  long .
             Data: 
            <            >  1F 1F 1F 1F 1F CD CD CD CD CD 


                     F:\CodeSample\Test\TestPipe\LeakTest\MainFrm.cpp(54) 告訴我們MFC認為是在該文件的54行,發(fā)生了內(nèi)存泄漏。你雙擊改行就可以轉(zhuǎn)到該文件的54行了。但是有時候這一信息并不能用來準確判斷,比如:MFC可能報告Strcore.cpp文件的某行,實際上這是CString的實現(xiàn)函數(shù),此時并不知道什么時候發(fā)生了內(nèi)存泄漏。

                     此時我們需要更多的信息。那么我們看看緊接其后的:

            { 86 normal block at  0x00422E80 10  bytes  long .
             Data: 
            <            >  1F 1F 1F 1F 1F CD CD CD CD CD 


                     它告訴我們:在第86次分配的內(nèi)存沒有釋放,一共有10字節(jié),內(nèi)容移16進制方式打印給我們看。

                     有了這些信息,我們可以開始調(diào)試內(nèi)存泄漏了。

                     按下F10在程序的剛開始處,停下來,打開Watch窗口:

            image002.jpg

                     在Watch窗口中輸入:

            {,,msvcrtd.dll}_crtBreakAlloc


              image003.jpg

                     然后更改值為上文提到的分配次數(shù):86

            image004.jpg

                     接著按下F5繼續(xù),然后在第86次分配的時候會發(fā)生中斷:

            image005.jpg

                     然后我們打開堆棧窗口:

            image006.jpgimage007.jpg

                  往回查看最近我們自己的代碼,雙擊堆棧我們自己的函數(shù)那一層,上圖有綠色三角的那一層。就定位到泄漏時分配的內(nèi)存了。

            image008.jpg

                     之后,就是看你的編碼功底了。




             

            你也許還沒用過的vc++的調(diào)試的功能

            From: http://www.cnitblog.com/Raistlin/archive/2005/12/14/5380.html

            剛剛在IT博客網(wǎng)閑逛的時候看到了孤獨的夜的一片文章《如何調(diào)試MFC中的內(nèi)存泄漏》,講道用設(shè)置{,,msvcrtd.dll}_crtBreakAlloc這個變量來調(diào)試內(nèi)存泄露的問題。

            How to use _crtBreakAlloc to debug a memory allocation你可以找到英文的更完整的版本,靜態(tài)鏈接和動態(tài)連接到C運行庫的名稱是不一樣的
            靜態(tài):_crtBreakAlloc
            動態(tài):{,,msvcr40d.dll}*__p__crtBreakAlloc()  (vc++4.0 和4.1版本,估計沒人在用吧)
                     {,,msvcrtd.dll}*__p__crtBreakAlloc()  (Visual C++ 4.2 or later)
                     {,,msvcrtd.dll}_crtBreakAlloc (好像這樣也是可以的)


            {,,msvcrtd.dll}__p__crtBreakAlloc()是個什么東西呢?

            查看msdn索引“Advanced Breakpoint”and you will find out...

            語法如下:
            {[function],[source],[exe] } location
            {[function],[source],[exe] } variable_name
            {[function],[source],[exe] } expression_r_r
            這個是我轉(zhuǎn)的時候的地址:http://blog.sina.com.cn/s/blog_630d564a0100gq5k.html

            posted on 2012-07-27 19:20 陳志遠 閱讀(454) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            導(dǎo)航

            <2012年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆檔案

            文章分類

            Othor's blog

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            …久久精品99久久香蕉国产| 久久久久国产精品麻豆AR影院| 99久久香蕉国产线看观香| 亚洲国产成人精品久久久国产成人一区二区三区综 | 999久久久免费国产精品播放| 88久久精品无码一区二区毛片| 久久久久99精品成人片三人毛片| 久久乐国产综合亚洲精品| 亚洲AV无码成人网站久久精品大| 2022年国产精品久久久久| 欧美一级久久久久久久大片| 777午夜精品久久av蜜臀| 久久99毛片免费观看不卡| 久久99这里只有精品国产| 国产精品久久国产精麻豆99网站| 国产午夜精品久久久久九九电影| 久久久久亚洲AV成人网人人网站 | 久久乐国产综合亚洲精品| 久久99国产精品久久99| 久久99久久99精品免视看动漫 | 青青草国产精品久久| 久久综合亚洲鲁鲁五月天| 久久91精品综合国产首页| 亚洲AV无码久久| 久久香综合精品久久伊人| 久久久久国产| 久久综合狠狠综合久久激情 | 久久久久久伊人高潮影院| 国产高潮久久免费观看| 国产精品久久久久久搜索| 伊人色综合久久天天人手人婷| 久久久久久久综合综合狠狠| 99久久伊人精品综合观看| 国产欧美一区二区久久| 久久精品国产亚洲av日韩| 久久亚洲中文字幕精品有坂深雪 | 精品久久久久久久久久久久久久久 | 欧美午夜A∨大片久久| 91精品国产91热久久久久福利| 久久久一本精品99久久精品66 | 精品99久久aaa一级毛片|