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.可以直接定位最后一个内存泄漏的位置

扫描二维码关注公众号,回复: 13424947 查看本文章

 2.这时候不需要打断点,它自己会停在最后76出错的那个地方

 

 3.打开调用堆栈,就可以查到出错的地方

 2.使用vs的诊断工具

1.调试-》窗口-》显示诊断工具

 2.在要调试的地方打断点,诊断窗口选择内存使用率

 3.到第一个断点处,点击截取快照

 

 4.执行下一句断点调试,再点击截取快照,如果内存使用增加就会出现变化

 5.点击快照第二条信息,就会出现信息,选择类型试图

 6.选择点击char[]这一条,会出现

 7.选择调用堆栈,右击可以转到源码处,查看代码泄漏的地方

猜你喜欢

转载自blog.csdn.net/qq_38409301/article/details/121193887
今日推荐