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

系统 1800 0

 

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

 

具体的现象如下图所示:


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

断点的堆栈如下:


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

当时就觉得非常奇怪。到网上搜索了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

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


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论