主要方法:利用系統帶的函數:EnableMemLeakCheck() 和 函數重載,能快速準備的定位到內存泄漏的地方,方法簡單且實用,值得借用。
#include <crtdbg.h>
#ifdef _DEBUG //重載一下new函數,這樣能得到使用new 開闢空間而發生泄漏的文件和所在行,這就是定位
#define new new(_NORMAL_BLOCK, __FILE__, __LINE__)
#endif
void EnableMemLeakCheck() //用於檢測是否有內存泄漏。
{
_CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG)|_CRTDBG_LEAK_CHECK_DF);
}
void main()
{
EnableMemLeakCheck();
int *leak = new int[10];
}
運行後得到的消息:
Loaded 'C:/WINNT/System32/ntdll.dll', no matching symbolic information found.
Loaded 'C:/WINNT/system32/kernel32.dll', no matching symbolic information found.
Detected memory leaks!
Dumping objects ->
D:/DS_Learn/meleak/test1.cpp(19) : {39} normal block at 0x00430120, 40 bytes long.
Data: < > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD
Object dump complete.
The thread 0x91C has exited with code 4391200 (0x430120).
The program 'D:/DS_LEARN/meleak/Debug/meleak.exe' has exited with code 4391200 (0x430120).
很快就能定位到內存泄漏的地方。
我原來也利用相關的方法,在C代碼中,重載malloc 和 free,也能很好的檢測有沒有內存泄漏和發生泄漏的地方,方法都很簡單,其實自己在寫代碼注意一下結構,還是很容易避免發生內存泄漏。
平時喜歡用這樣的結構:
projectname_init(); //在初始化時,開闢好空間,對project中一些變量,如結構體開闢空間
projectname_process(); //作相關的處理
projectname_uninit(); //結束程序運行,釋放所以動態分配的空間。