CString發生內存泄露

MFC對話框程序在退出時,發生了內存泄露:

Detected memory leaks!
Dumping objects ->
{98500} normal block at 0x05785AD0, 152 bytes long.
Data: << N       N x 7 > 3C AC 4E 10 00 00 00 00 BC A4 4E 10 78 B6 37 00
Object dump complete.

98500

而且每次退出都是一樣的.泄漏的內存塊都是98500.

是CSring寫的有問題。你使用字符串的代碼部分是不是有問題

解決方法1:

1. 在程序開始啓動的地方(足夠前的地方,只要在泄漏的內存分配的前面)使用代碼:

_CrtSetBreakAlloc(98500); //98500爲上面內存泄漏的塊號.

2. 然後debug運行,程序自動斷點在"內存塊98500"分配的位置:

 

/* break into debugger at specific memory allocation */
if (_crtBreakAlloc != -1L && lRequest == _crtBreakAlloc)
_CrtDbgBreak();

3 .我們已經找到了泄漏的那塊內存分配的底層操作的地方了(好拗口!).

這個時候我們利用 "調試" –> "退出" ,快捷鍵爲:"Shift + F11" .

跳出當前函數..然後一直往"上"跳,邊跳邊查看調用棧.直到看到了自己寫的代碼,例如我的

std::ifstream* origStream = new std::ifstream();

4 .這個時候我已經可以判斷 origStream 分配了內存,但是沒有合理釋放.處理後再次運行就沒有出現內存泄漏了.

5.最後,記得把_CrtSetBreakAlloc(98500); 這句話刪除掉,不然每次都斷點,豈不是煩死..

 

解決方法2:

匹配控件中的 new delete 
在  .cpp 中添加, 這樣在DEBUG模式下提示信息可能會更加明顯些

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章