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

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产69精品久久久久99| www.久久99| 久久精品国产欧美日韩99热| 久久亚洲国产精品成人AV秋霞| 中文国产成人精品久久不卡| 72种姿势欧美久久久久大黄蕉| 一本一道久久精品综合| 伊人久久大香线蕉综合5g| 老色鬼久久亚洲AV综合| 久久国产精品免费| 久久久一本精品99久久精品66| 国产免费久久精品99久久| 18岁日韩内射颜射午夜久久成人| 久久99精品久久久久久| 亚洲国产精品成人AV无码久久综合影院 | 亚洲午夜久久久久久噜噜噜| 久久精品国产精品亚洲精品| 久久精品成人欧美大片| 久久99精品久久久久久野外| 99久久无码一区人妻a黑| 久久国内免费视频| 亚洲精品美女久久久久99小说| 国产精品久久久久久搜索| 精品人妻伦九区久久AAA片69| 久久99国产一区二区三区| 成人国内精品久久久久一区| 亚洲熟妇无码另类久久久| 日本国产精品久久| 久久露脸国产精品| 国产福利电影一区二区三区,免费久久久久久久精 | 日韩va亚洲va欧美va久久| 亚洲国产精品久久| 久久久久久久综合日本亚洲| 三上悠亚久久精品| 久久综合综合久久综合| 99精品国产99久久久久久97| 老男人久久青草av高清| 狠狠色丁香久久婷婷综合蜜芽五月| 日产久久强奸免费的看| 久久笫一福利免费导航| 欧美精品九九99久久在观看|