?
中午吃飯的時候跟同事聊天說起一個問題。說是在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。
?
?參考:
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
