VC++ IDE 的默認狀態(VC6)是沒有啓用內存泄漏檢測機制的,也就是說即使某段代碼有內存泄漏,調試會話的 Output 窗口的 Debug 頁不會輸出有關內存泄漏信息。你必須設定以啓用內存泄漏檢測機制。
在XXXView.cpp中添加下面粗體行
你再看看輸出結果,是不是有很多的內存泄漏?
#define _CRTDBG_MAP_ALLOC
#include<stdlib.h>
#include<crtdbg.h>
{
}
首先,應該是MFC報告我們發現內存泄漏。注意:要多運行幾次,以確定輸出的內容不變,特別是{}之間的數值,不能變,否則下面的方法就不好用了。
我們來看看:
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行,發生了內存泄漏。你雙擊改行就可以轉到該文件的54行了。但是有時候這一信息並不能用來準確判斷,比如:MFC可能報告Strcore.cpp文件的某行,實際上這是CString的實現函數,此時並不知道什麼時候發生了內存泄漏。
此時我們需要更多的信息。那麼我們看看緊接其後的:
{86} normal block at 0x00422E80, 10 bytes long.
Data: < > 1F 1F 1F 1F 1F CD CD CD CD CD
它告訴我們:在第86次分配的內存沒有釋放,一共有10字節,內容移16進制方式打印給我們看。
有了這些信息,我們可以開始調試內存泄漏了。
按下F10在程序的剛開始處,停下來,打開Watch窗口:
在Watch窗口中輸入:
{,,msvcrtd.dll}_crtBreakAlloc
然後更改值爲上文提到的分配次數:86
接着按下F5繼續,然後在第86次分配的時候會發生中斷
然後我們打開堆棧窗口:
往回查看最近我們自己的代碼,雙擊堆棧我們自己的函數那一層,上圖有綠色三角的那一層。就定位到泄漏時分配的內存了。
之後,就是看你的編碼功底了。