调试MFC内存泄露——实战分析

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

debug输入信息

 

我们来看看:

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窗口:

View / Debug Windows / Watch

 

在Watch窗口中输入:

{,,msvcrtd.dll}_crtBreakAlloc

在Watch窗口中输入:{,,msvcrtd.dll}_crtBreakAlloc

 

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

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

 

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

User breakpoint called from code at 0x10211920

 

然后我们打开堆栈窗口:

打开堆栈窗口:

 

可以看到如下信息:

堆栈信息

 

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

定位

 

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

 

 

 

 

本文转自:http://white313.blog.163.com/blog/static/21026200611903653959/

 

相关文章:免费的内存泄漏检测工具Visual Leak Detector

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汪宁宇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值