VC 内存检测 转http://blog.163.com/feiqiu_20/blog/static/168971908200711955027604/

来源:互联网 发布:阿里云mysql数据库 编辑:程序博客网 时间:2024/05/08 18:28

[VC]内存泄露检测  

2007-12-09 17:50:27|  分类: 技术文章|字号 订阅

VC++ IDE 的默认状态(VC6)是没有启用内存泄漏检测机制的,也就是说即使某段代码有内存泄漏,调试会话的 Output 窗口的 Debug 页不会输出有关内存泄漏信息。你必须设定以启用内存泄漏检测机制。

按下面的方法使用调试堆函数,你再看看输出结果,是不是有很多的内存泄漏?

#define _CRTDBG_MAP_ALLOC 
#include<stdlib.h> 
#include<crtdbg.h>

CXXXView::~CXXXView()
{
      _CrtDumpMemoryLeaks(); 
}

首先,应该是MFC报告我们发现内存泄漏。注意:要多运行几次,以确定输出的内容不变,特别是{}之间的数值,不能变,否则下面的方法就不好用了。   [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

我们来看看:

F: CodeSample Test TestPipe LeakTest MainFrm.cpp(54) : {86} normal block at 0x00422E80, 10 bytes long.
Data: <          > 1F 1F 1F 1F 1F CD CD CD CD CD

F: CodeSample Test TestPipe LeakTest MainFrm.cpp(54) 告诉我们MFC认为是在该文件的54行,发生了内存泄漏。你双击改行就可以转到该文件的54行了。但是有时候这一信息并不能用来准确判断,比如:MFC可能报告Strcore.cpp文件的某行,实际上这是CString的实现函数,此时并不知道什么时候发生了内存泄漏。

此时我们需要更多的信息。那么我们看看紧接其后的:

{86} normal block at 0x00422E80, 10 bytes long.
Data: <          > 1F 1F 1F 1F 1F CD CD CD CD CD

它告诉我们:在第86次分配的内存没有释放,一共有10字节,内容移16进制方式打印给我们看。

有了这些信息,我们可以开始调试内存泄漏了。按下F10在程序的刚开始处,停下来,打开Watch窗口:

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

在Watch窗口中输入:

{,,msvcrtd.dll}_crtBreakAlloc

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

然后更改值为上文提到的分配次数:86

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

接着按下F5继续,然后在第86次分配的时候会发生中断

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

然后我们打开堆栈窗口:

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

往回查看最近我们自己的代码,双击堆栈我们自己的函数那一层,上图有绿色三角的那一层。就定位到泄漏时分配的内存了。

  [VC]内存泄露检测 - 飞秋,www.freeeim.com - 飞秋官网

之后,就是看你的编码功底了。