vs内存泄漏三种检测方式
1.采用重载new
详解:C++内存泄露检测原理_nodeathphoenix的专栏-CSDN博客
具体操作步骤:
1.重载头文件Memdect.h
#pragma once
/* GBK */
// VS支持的内存泄露检测
#define _CRTDBG_MAP_ALLOC
#include<cstdlib>
#include<crtdbg.h>
#ifdef _DEBUG
#ifndef DBG_NEW
#define DBG_NEW new(_NORMAL_BLOCK,__FILE__,__LINE__)
#define new DBG_NEW
#endif // !DBG_NEW
#endif // _DEBUG
/* 内存检测 */
#define MEMORYDETECTION _CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF)
/* 指定位置进入内存申请断点 */
#define MEMORYPOSITIONING(a) _CrtSetBreakAlloc(a)
/**
* 说明:
* 通过重新定义new,来实现定位到泄露的文件、行号
* 该行为定义为,只在debug模式下有效。
* 当您在debug模式下使用new申请内存时,产生的泄露,会给出具体的泄露位置。
* 当您在使用其他的内存申请工具时,只提示内存的申请次数。如malloc,您可通过定位宏在进入调试后进入泄露的位置。
*/
/**
* 使用方法:
* 在你需要检测的函数内使用宏 MEMORYDETECTION 来检测此宏以下的内存申请
* 在你需要进入内存申请次数的位置时,使用宏 MEMORYPOSITIONING(a) 来指定位置,该参数通常使用 MEMORYDETECTION 来获得
*/
(1)测试泄漏代码,new两个变量不释放
void LeakTest()
{
char* memory = new char[10];
int* b = new int[20];
}
int main()
{
MEMORYDETECTION;//放在要检测的代码地方
LeakTest();
return 0;
}
(2)释放new对象,不报错
void LeakTest()
{
char* memory = new char[10];
int a = 10;
memcpy(memory, &a, sizeof(a));
if (nullptr != memory)
{
delete[] memory;
memory = nullptr;
}
}
int main()
{
MEMORYDETECTION;
LeakTest();
return 0;
}
(3)判断return,没执行delete,报错
void LeakTest()
{
char* memory = new char[10];
int a = 10;
memcpy(memory, &a, sizeof(a));
if (a==10)
{
return;
}
if (nullptr != memory)
{
delete[] memory;
memory = nullptr;
}
}
int main()
{
MEMORYDETECTION;
LeakTest();
return 0;
}
(4)MEMORYPOSITIONING(a)使用方法
1.可以直接定位最后一个内存泄漏的位置
2.这时候不需要打断点,它自己会停在最后76出错的那个地方
3.打开调用堆栈,就可以查到出错的地方
2.使用vs的诊断工具
1.调试-》窗口-》显示诊断工具
2.在要调试的地方打断点,诊断窗口选择内存使用率
3.到第一个断点处,点击截取快照
4.执行下一句断点调试,再点击截取快照,如果内存使用增加就会出现变化
5.点击快照第二条信息,就会出现信息,选择类型试图
6.选择点击char[]这一条,会出现
7.选择调用堆栈,右击可以转到源码处,查看代码泄漏的地方
3.采用visual leak detector工具进行检测
VS内存泄漏检测工具Visual Leak Detector(debug|release)_qq_1410888563的博客-CSDN博客