如何调试MFC中的内存泄漏

本文介绍了一种使用Visual C++调试MFC应用程序中内存泄漏的方法。通过设置_crtBreakAlloc变量,可以在特定的内存分配发生时中断程序执行,进而定位到泄漏源头。此方法对于解决MFC内存管理问题非常有效。

转载地址:http://www.cnitblog.com/martin/archive/2006/04/21/9460.html

首先,应该是MFC报告我们发现内存泄漏。注意:要多运行几次,以确定输出的内容不变,特别是{}之间的数值,不能变,否则下面的方法就不好用了。

image001

我们来看看:

F:\CodeSample\Test\TestPipe\LeakTest\MainFrm.cpp( 54 ):{ 86 }normalblockat 0x00422E80 , 10 bytes long .
Data:
< > 1F1F1F1F1FCDCDCDCDCD


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



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

{ 86 }normalblockat 0x00422E80 , 10 bytes long .
Data:
< > 1F1F1F1F1FCDCDCDCDCD


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

有了这些信息,我们可以开始调试内存泄漏了。

按下F10在程序的刚开始处,停下来,打开Watch窗口:

image002

在Watch窗口中输入:

{,,msvcrtd.dll}_crtBreakAlloc

image003

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

image004

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

image005

然后我们打开堆栈窗口:

image006

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

image008

你也许还没用过的vc++的调试的功能

From: http://www.cnitblog.com/Raistlin/archive/2005/12/14/5380.html

刚刚在IT博客网闲逛的时候看到了孤独的夜 的一片文章《如何调试MFC中的内存泄漏 》,讲道用设置{,,msvcrtd.dll}_crtBreakAlloc这个变量 来调试内存泄露的问题。

How to use _crtBreakAlloc to debug a memory allocation 你可以找到英文的更完整的版本,静态链接和动态连接到C运行库的名称是不一样的
静态:_crtBreakAlloc
动态:{,,msvcr40d.dll}*__p__crtBreakAlloc() (vc++4.0 和4.1版本,估计没人在用吧)
{,,msvcrtd.dll}*__p__crtBreakAlloc() (Visual C++ 4.2 or later)
{,,msvcrtd.dll}_crtBreakAlloc (好像这样也是可以的)


{,,msvcrtd.dll}__p__crtBreakAlloc()是个什么东西呢?

查看msdn索引“Advanced Breakpoint”and you will find out...

语法如下:
{[function],[source],[exe] } location
{[function],[source],[exe] } variable_name
{[function],[source],[exe] } expression








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值