VC++ IDE 的默認(rèn)狀態(tài)(VC6)是沒(méi)有啟用內(nèi)存泄漏檢測(cè)機(jī)制的,也就是說(shuō)即使某段代碼有內(nèi)存泄漏,調(diào)試會(huì)話(huà)的 Output 窗口的 Debug 頁(yè)不會(huì)輸出有關(guān)內(nèi)存泄漏信息。你必須設(shè)定以啟用內(nèi)存泄漏檢測(cè)機(jī)制。 按下面的方法使用調(diào)試堆函數(shù),你再看看輸出結(jié)果,是不是有很多的內(nèi)存泄漏? #define _CRTDBG_MAP_ALLOC CXXXView::~CXXXView() { _CrtDumpMemoryLeaks(); } 首先,應(yīng)該是MFC報(bào)告我們發(fā)現(xiàn)內(nèi)存泄漏。注意:要多運(yùn)行幾次,以確定輸出的內(nèi)容不變,特別是{}之間的數(shù)值,不能變,否則下面的方法就不好用了。 我們來(lái)看看: F: CodeSample Test TestPipe LeakTest MainFrm.cpp(54) : {86} normal block at 0x00422E80, 10 bytes long. F: CodeSample Test TestPipe LeakTest MainFrm.cpp(54) 告訴我們MFC認(rèn)為是在該文件的54行,發(fā)生了內(nèi)存泄漏。你雙擊改行就可以轉(zhuǎn)到該文件的54行了。但是有時(shí)候這一信息并不能用來(lái)準(zhǔn)確判斷,比如:MFC可能報(bào)告Strcore.cpp文件的某行,實(shí)際上這是CString的實(shí)現(xiàn)函數(shù),此時(shí)并不知道什么時(shí)候發(fā)生了內(nèi)存泄漏。 此時(shí)我們需要更多的信息。那么我們看看緊接其后的: {86} normal block at 0x00422E80, 10 bytes long. 它告訴我們:在第86次分配的內(nèi)存沒(méi)有釋放,一共有10字節(jié),內(nèi)容移16進(jìn)制方式打印給我們看。 有了這些信息,我們可以開(kāi)始調(diào)試內(nèi)存泄漏了。按下F10在程序的剛開(kāi)始處,停下來(lái),打開(kāi)Watch窗口: 在Watch窗口中輸入: {,,msvcrtd.dll}_crtBreakAlloc
然后更改值為上文提到的分配次數(shù):86 接著按下F5繼續(xù),然后在第86次分配的時(shí)候會(huì)發(fā)生中斷 然后我們打開(kāi)堆棧窗口: 往回查看最近我們自己的代碼,雙擊堆棧我們自己的函數(shù)那一層,上圖有綠色三角的那一層。就定位到泄漏時(shí)分配的內(nèi)存了。
|
|
來(lái)自: 勤奮不止 > 《開(kāi)發(fā)工具visualstudio》