青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACG狂人

其實我更愛姐汁...

析構過程中內存相關錯誤的絕大多數原因

今天記錄一下長久以來屢次犯的錯,每次都是換一種方法編碼來繞過這個問題實現功能的,因為這個問題太過隱蔽,導致今天才發現其中真正的原因...下面進行問題描述:
1std::map<std::string, Value> keyValue; // 在函數內部分配的堆棧對象(局部變量)
2ReadData(keyValue);// 從dll中導出的函數
3keyValue.clear(); // delete中出現assert異常

第一行是在應用程序中的堆棧中分配的內存空間。
第二行是我自己寫的dll庫,用來讀取一些數據加入到keyValue中。
第三行是清空keyValue,其實如果不寫這一行的話,keyValue也會在函數結尾時清空,到那時同樣會出現錯誤。
這一切乍一看沒啥問題,keyValue是局部變量,為什么局部變量的釋放會出現異常錯誤呢?這是因為第二行ReadData的緣故。ReadData的邏輯在另外一個可執行模塊中,在其中分配的內存空間不一定與當前模塊在同一個堆區。
我們知道,std::map是一個樹結構的容器,我在ReadData內部往keyValue中添加了數據,keyValue中會在堆區中分配樹節點,而這個節點將會在當前模塊在keyValue的析構中被釋放。也就是說,我無意中在dll模塊中分配了堆空間,又無意中在exe模塊中企圖釋放該空間,這樣的行為導致錯誤是不足為怪的。
時刻牢記,在一個模塊中分配和釋放同一塊內存區域,警惕你所看不見的內存分配和釋放。

posted on 2010-07-01 15:47 釀妹汁 閱讀(3394) 評論(11)  編輯 收藏 引用 所屬分類: C++備忘

評論

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-01 17:09 陳梓瀚(vczh)

你的錯誤是因為dll的std::map跟你這里的std::map不是使用同一份代碼,而是兩份代碼。所以不要拿stl的模板容器去跨dll。所以這種時候,你應該去包裝一個不能再.h看到實現的StringValueMap然后暴露出來,或者不要用dll直接使用它的代碼。  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-01 18:30 hxhxd

看到了dll導出了一個wrap std::string 的std:map,嚴重懷疑std:string的copy-on-write 使得兩個模塊引用了同一個stringbuffer,然后dll模塊的unload或者exe模塊的clear都有可能導致對方模塊在進一步的操作中access violation.  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-01 18:48 壞人

dll導出函數 應該是純C的  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因[未登錄] 2010-07-01 19:34 路人甲

本人喜歡鉆牛角尖,博主能否把測試代碼發給我(alcoholyi@qq.com)。
另外,你下的結論有誤,沒有什么exe,dll模塊堆空間一說,堆只跟進程有關系,可以簡單的理解為同一個進程的dll和exe共享一個堆空間。
  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-01 21:15 Forrest

我覺得實際上是你的DLL接口設計有問題,從來就沒有見到過接口有使用map的,一般接口的定義只使用C語言的接口,遵守資源誰分配誰釋放的原則,如果使用C++的接口的話,比如map,資源的分配釋放就分不清楚了.  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-01 21:28 Forrest

@路人甲
有道理  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-02 02:18 Mensch88

完全贊同vczh的觀點。lz的ReadData肯定是在另一個庫里面編譯的,而那個庫調用的STL lib與現在的項目不同。這跟模塊沒有任何關系。
我最近也一直碰到這種情況。使用別人的第三方程序庫,Release能跑,而Debug里面一碰到傳遞string就出錯。郁悶。
有誰知道如何能查看第三方庫到底link了哪些dll么?
  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-02 10:33 老安

確實有一種情況,
在window下遇到過,兩個dll,在其中一個dll中new一個object,然后在另外一個dll delete,崩潰。
環境是winxp vc6.
很久之前了。

但是你這種玩法是問題復雜化了。  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-02 12:28 ebencheung

@你的錯誤是因為dll的std::map跟你這里的std::map不是使用同一份代碼,而是兩份代碼

嚴重同意上述觀點.template是源代碼級的復用.請勿跨二進制使用.  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2010-07-08 14:35

回LS幾位的話...釋放內存的時候,系統提示為已經釋放過的內存塊或是在不同的堆中分配的內存。也許提示的不正確,但是本著誰分配誰釋放的原則的話,就算在模塊接口上使用std的容器也應該沒什么問題。
這方面只要注意在兩個模塊中使用同樣的clib鏈接方式就可以,分為debug、release、static、dynamic的命名方式,項目中存在多種配置,都是統一的。  回復  更多評論   

# re: 析構過程中內存相關錯誤的絕大多數原因 2013-12-26 13:24 smilelittle

這個常見的錯誤,“2010-07-08 14:35 釀”說的對。原因在于dll和exe鏈接了不同基礎lib導致,把它們全部設置成一樣的,就沒問題了。  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            91久久国产自产拍夜夜嗨| 亚洲国产经典视频| 亚洲一区二区三区视频| 夜夜爽99久久国产综合精品女不卡 | 欧美成人免费网站| 亚洲欧洲综合另类在线| 亚洲国产美女精品久久久久∴| 久久深夜福利| 亚洲精品一区久久久久久| 日韩视频二区| 国产免费成人在线视频| 麻豆国产精品一区二区三区| 蘑菇福利视频一区播放| 这里只有精品丝袜| 亚洲欧美国产精品va在线观看| 激情综合激情| 亚洲精选大片| 国产视频欧美视频| 亚洲第一毛片| 国产精品资源| 欧美激情亚洲国产| 国产精品日韩在线播放| 蜜桃精品一区二区三区| 欧美午夜视频网站| 男人天堂欧美日韩| 欧美性感一类影片在线播放 | 国产在线麻豆精品观看| 欧美国产日韩一区二区| 欧美日韩亚洲成人| 久久一区二区三区av| 欧美精品久久天天躁| 久久精品一二三| 欧美精品一区二区精品网| 久久精品在线免费观看| 欧美精品三区| 毛片一区二区三区| 国产精品一区二区三区乱码 | 一本色道久久精品| 久久se精品一区精品二区| 一本色道久久综合亚洲精品按摩| 性欧美xxxx大乳国产app| 亚洲精品综合| 久久一区二区三区超碰国产精品| 午夜精品久久久久久久蜜桃app| 麻豆精品在线播放| 久久久夜夜夜| 国产日韩精品一区二区三区| 亚洲精品国产精品久久清纯直播| 国产在线乱码一区二区三区| 亚洲色无码播放| 一本色道久久88精品综合| 久久免费高清视频| 久久免费视频这里只有精品| 国产精品色午夜在线观看| 一本色道久久加勒比88综合| 亚洲激精日韩激精欧美精品| 久久九九国产| 久久露脸国产精品| 国产欧美日韩在线视频| 亚洲一区二区三区高清| 亚洲欧美日韩综合一区| 欧美三级不卡| 中国成人亚色综合网站| 在线亚洲欧美视频| 欧美日韩国产亚洲一区| 亚洲精品麻豆| 亚洲天堂av图片| 欧美午夜无遮挡| 亚洲一区二区三区精品视频| 亚洲欧美日本伦理| 国产精品日日摸夜夜摸av| 亚洲综合色网站| 久久激情综合网| 国内精品美女在线观看| 久久免费高清视频| 欧美激情亚洲自拍| 一区二区三区免费观看| 国产精品盗摄一区二区三区| 亚洲一二三区在线| 久久精品网址| 亚洲国产精品99久久久久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎 | 99精品欧美一区二区蜜桃免费| 牛牛国产精品| 日韩一级大片在线| 性欧美1819sex性高清| 国产亚洲福利| 可以看av的网站久久看| 亚洲人成人一区二区三区| 亚洲一区二区在| 国产亚洲精品aa午夜观看| 国产麻豆日韩欧美久久| 亚洲欧美一区二区激情| 久热这里只精品99re8久| 亚洲精品资源美女情侣酒店| 国产精品国产三级国产aⅴ浪潮| 性伦欧美刺激片在线观看| 欧美大色视频| 亚洲欧美影音先锋| 亚洲高清一二三区| 国产精品人人做人人爽人人添| 久久狠狠一本精品综合网| 亚洲人人精品| 久久久久综合| 亚洲无限乱码一二三四麻| 国产一区日韩欧美| 欧美日韩精品免费看| 久久精品视频在线播放| 亚洲六月丁香色婷婷综合久久| 久久精品视频免费观看| 亚洲视频免费| 亚洲高清不卡| 国产欧美亚洲精品| 欧美人妖在线观看| 麻豆乱码国产一区二区三区| 亚洲欧美日韩久久精品| 亚洲日本中文字幕免费在线不卡| 久久久久久久欧美精品| 亚洲一区高清| 一本色道久久| 亚洲国产一区二区三区在线播| 国产精品区一区| 欧美精品久久一区| 免费黄网站欧美| 久久精品国产在热久久| 亚洲一品av免费观看| 亚洲欧洲精品一区二区精品久久久| 久久国产精品久久久久久| 亚洲婷婷国产精品电影人久久| 亚洲黄色免费| 亚洲国产精品成人精品| 国精品一区二区三区| 国产精品嫩草影院一区二区| 欧美激情精品久久久| 免费在线观看一区二区| 久久午夜av| 久久久久88色偷偷免费| 久久99在线观看| 先锋影音国产精品| 翔田千里一区二区| 亚洲综合欧美日韩| 亚洲欧美综合| 亚洲欧美国产精品va在线观看 | 美女久久一区| 久久久欧美精品| 久久久久久久久久看片| 午夜精品一区二区三区电影天堂 | 久久久噜噜噜久久中文字免| 性久久久久久久久久久久| 亚洲欧美日韩国产一区二区三区| 一区二区三区视频免费在线观看| 日韩一区二区电影网| 日韩一二三在线视频播| 一区二区三区日韩欧美精品| 一级成人国产| 亚洲欧美另类久久久精品2019| 亚洲欧美日韩在线| 久久国产色av| 久久亚洲综合色一区二区三区| 久久久久久穴| 免播放器亚洲一区| 亚洲欧洲一二三| 在线视频欧美日韩| 欧美在线播放一区二区| 久久精品一区二区三区四区 | 亚洲午夜精品17c| 亚洲欧美一区二区原创| 久久久精品性| 欧美激情在线播放| 亚洲视频在线看| 久久成人18免费网站| 理论片一区二区在线| 亚洲精品视频在线播放| 亚洲尤物在线| 久久一区二区精品| 欧美视频在线观看免费| 国产欧美日韩专区发布| 亚洲成人在线视频网站| 一级日韩一区在线观看| 午夜久久久久久| 欧美成人资源| 亚洲一区在线观看免费观看电影高清| 香蕉亚洲视频| 欧美日韩午夜剧场| 激情文学综合丁香| 中文在线不卡| 欧美成人午夜免费视在线看片| 99国产一区| 久久久亚洲高清| 国产精品日韩在线| 亚洲免费播放| 裸体歌舞表演一区二区| 亚洲一区二区在| 欧美激情第4页| 黄色亚洲在线| 亚洲专区在线视频| 亚洲激情成人网| 久久野战av| 国内自拍亚洲| 欧美一区亚洲二区|