1. 判斷方法
在程序vs編寫代碼,在想要追蹤的方法結尾,使用_CrtDumpMemoryLeaks()函數可以檢測是否內存泄漏。推薦在main函數結尾使用,追蹤範圍更大。
#include <iostream>
int main()
{
char* c1 = (char*)malloc(15);
delete c1;
char* c = (char*)malloc(15);
char* c3 = (char*)malloc(15);
_CrtDumpMemoryLeaks();
}
通過f5調試執行完成後,在輸出窗口,注意是輸出窗口,不是控制檯窗口,看到如下提示就表示有內存泄漏了。
Detected memory leaks!
Dumping objects ->
{153} normal block at 0x00F04D68, 15 bytes long.
Data: < > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD
{152} normal block at 0x00F092F0, 15 bytes long.
Data: < > CD CD CD CD CD CD CD CD CD CD CD CD CD CD CD
Object dump complete.
2. 上述內容涵義(從第三行開始看起)
內存分配編號(在大括號內)。
塊類型(普通、客戶端或 CRT)。
十六進制形式的內存位置。
以字節爲單位的塊大小。
前 16 字節的內容(亦爲十六進制)
3. 如何定位哪裏內存泄漏?
3.1 通過_CrtSetBreakAlloc()函數,把內存分配編號作爲參數,就會在f5執行時停止在問題位置。
#include <iostream>
int main()
{
_CrtSetBreakAlloc(152);
_CrtSetBreakAlloc(153);
char* c1 = (char*)malloc(15);
delete c1;
char* c = (char*)malloc(15);
char* c3 = (char*)malloc(15);
_CrtDumpMemoryLeaks();
}
3.2 通過_CrtSetDbgFlag()函數定位文件和位置
#include <iostream>
#define new new(_CLIENT_BLOCK, __FILE__, __LINE__)
int main()
{
_CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG) | _CRTDBG_LEAK_CHECK_DF);
int* p = new int;
_CrtDumpMemoryLeaks();
}
看到類似如下內容
Detected memory leaks!
Dumping objects ->
C:\Users\12250\source\repos\OnlyForTest\OnlyForTest2\main.cpp(17) : {151} client block at 0x00B7C270, subtype 0, 4 bytes long.
Data: < > CD CD CD CD
Object dump complete.
就表示是在我的解決方案“OnlyForTest”下的項目“OnlyForTest2”下的main.cpp文件第17行產生內存泄漏了。
最後, 覺得文章對你有用的話,給個下面的三連(點贊,收藏,打賞)吧!