VC中"其原因可能是堆被损坏"的原因解析

 

中午吃饭的时候跟同事聊天说起一个问题。说是在dll中delete在exe中创建的对象会弹出assert窗口并提醒说“堆破坏”。当时想想不太可能,回到公司后用VS2005试了一下没有出现问题。但是同事同VS2003新建了项目和工程后却出现了该问题。

 

具体的现象如下图所示:


断点的堆栈如下:


当时就觉得非常奇怪。到网上搜索了crtheap就有预感可能是crtheap的问题。

后来就搜到了微软的这篇文章,dll间传递CRT对象(文件句柄、环境变量、区域信息等)存在潜在问题。

 

进程分配内存(显式调用new,allocate,隐式分配内存比如调用strdup,strstreambuf::str等)

然后传递给DLL进行释放。都可能因为使用了不同的CRT库造成内存非法访问和栈破坏。

 

每一份CRT库的都有独立和唯一一份状态,并且每一份CRT库都有自己的对管理器。DLL和EXE可能使用了不同的CRT库,所以分配和释放内存的堆不能匹配从而导致了堆破坏。

 

修复方法:

EXE和所有的DLL都必须动态链接/MD到同一份CRT。

 


 参考:

http://msdn.microsoft.com/zh-cn/library/ms235460.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值