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

大龍的博客

常用鏈接

統計

最新評論

(轉)跨dll訪問STL的map的問題

問題:跨dll,針對Vector引用的傳遞沒有問題,但是Map就出現問題了。

原因分析:
一句話-----如果任何STL類使用了靜態變量(無論是直接還是間接使用),那么就不要再寫出跨執行單元訪問它的代碼。 除非你能夠確定兩個動態庫使用 的都是同樣的STL實現,比如都使用VC同一版本的STL,編譯選項也一樣。強烈建議,不要在動態庫接口中傳遞STL容器!!

STL不一定不能在DLL間傳遞,但你必須徹底搞懂它的內部實現,并懂得為何會出問題。
微軟的解釋:
http://support.microsoft.com/default.aspx?scid=kb%3ben-us%3b172396
微軟給的解決辦法:
http://support.microsoft.com/default.aspx?scid=kb%3ben-us%3b168958

1、微軟的解釋:
大部分C++標準庫里提供的類直接或間接地使用了靜態變量。由 于這些類是通過模板擴展而來的,因此每個可執行映像(通常是.dll或.exe文件)就會存在一份只屬于自己的、給定類的靜態數據成員。當一個需要訪問這 些靜態成員的類方法執行時,它使用的是“這個方法的代碼當前所在的那份可執行映像”里的靜態成員變量。由于兩份可執行映像各自的靜態數據成員并未同步,這 個行為就可能導致訪問違例,或者數據看起來似乎丟失或被破壞了。

可能不太好懂,我舉個例子:假如類A<T>有個靜態變量m_s,那么當1.exe使用了2.dll中提供的某個A<int>對象時,由于模板擴展機制,1.exe和2.dll中會分別存在自己的一份類靜態變量A<int>.m_s。
這樣,假如1.exe中從2.dll中取得了一個的類A<int>的實例對象a,那么當在1.exe中直接訪問a.m_s時,其實訪問的是 1.exe中的對應拷貝(正確情況應該是訪問了2.dll中的a.m_s)。這樣就可能導致非法訪問、應當改變的數據沒有改變、不應改變的數據被錯誤地更 改等異常情形。

原文:
Most classes in the Standard C++ Libraries use static data members directly or indirectly. Since these classes are generated through template instantiation, each executable image (usually with DLL or EXE file name extensions) will contain its own copy of the static data member for a given class. When a method of the class that requires the static data member is executed, it uses the static data member in the executable image in which the method code resides. Since the static data members in the executable images are not in sync, this action could result in an access violation or data may appear to be lost or corrupted.

1、保證資源的分配/刪除操作對等并處于同一個執行單元;
   比如,可以把這些操作(包括構造/析構函數、某些容器自動擴容{這個需要特別注意}時的內存再分配等)隱藏到接口函數里面。換句話說:盡量不要直接從dll中輸出stl對象;如果一定要輸出,給它加上一層包裝,然后輸出這個包裝接口而不是原始接口

2、保證所有的執行單元使用同樣版本的STL運行庫。
   比如,全部使用release庫或debug庫,否則兩個執行單元擴展出來的STL類的內存布局就可能會不一樣。

只要記住關鍵就是:如果任何STL類使用了靜態變量(無論是直接還是間接使用),那么就不要再寫出跨執行單元訪問它的代碼。

解決方法:
1. 一個可以考慮的方案
比如有兩個動態庫L1和L2,L2需要修改L1中的一個map,那么我在L1中設置如下接口
int modify_map(int key, int new_value);
如果需要指定“某一個map”,則可以考慮實現一種類似于句柄的方式,比如可以傳遞一個DWORD
不過這個DWORD放的是一個地址

那么modify_map就可以這樣實現:
int modify_map(DWORD map_handle, int key, int new_value)
{
    std::map<int, int>& themap = *(std::map<int, int>*)map_handle;
    themap[key] = new_value;
}

map_handle的值也首先由L1“告訴”L2:
DWORD get_map_handle();

L2可以這樣調用:
DWORD h = get_map_handle();
modify_map(h, 1, 2);

2. 加入一個額外的層,就可以解決問題。所以,你需要將你的Map包裝在dll內部,而不是讓它出現在接口當中。動態庫的接口越簡單越好,不好去傳太過復雜的東東是至理名言:)

posted on 2009-06-16 17:08 大龍 閱讀(2603) 評論(1)  編輯 收藏 引用

評論

# re: (轉)跨dll訪問STL的map的問題 2009-07-08 14:32 劉林

很好,很強大  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产精品久久| 久久久久久久久久久久久9999| 欧美精品v国产精品v日韩精品| 亚洲欧美综合精品久久成人| 亚洲最新中文字幕| 亚洲午夜一区| 欧美在线高清视频| 鲁大师影院一区二区三区| 欧美一级网站| 亚洲欧美激情视频| 久久一区二区三区av| 欧美福利一区二区三区| 欧美日精品一区视频| 国产精品视频yy9299一区| 夜夜狂射影院欧美极品| 亚洲综合视频网| 亚洲小视频在线观看| 欧美一区二区三区在线视频| 中文亚洲欧美| 亚洲视屏在线播放| 9i看片成人免费高清| 欧美一区二区三区在线免费观看| 老色批av在线精品| 欧美日本韩国一区二区三区| 欧美日韩精品一区| 在线高清一区| 亚洲综合导航| 宅男66日本亚洲欧美视频| 性色一区二区三区| 亚洲电影在线免费观看| 欧美三区在线视频| 国产伦精品一区二区三区高清版 | 永久免费视频成人| 99国产精品| 久久精品国产v日韩v亚洲| 亚洲激情女人| 亚洲欧美精品| 欧美精品激情blacked18| 国产精品视频xxxx| 国产精品99久久99久久久二8| 久久久久久久久久码影片| 亚洲日本欧美日韩高观看| 久久精品国产精品亚洲综合| 国产精品久久久久婷婷| 99xxxx成人网| 亚洲人成毛片在线播放| 免费试看一区| 在线观看欧美激情| 美女主播精品视频一二三四| 欧美一区亚洲| 国产日韩精品视频一区| 亚洲欧美乱综合| 一区二区三区高清视频在线观看| 欧美国产日韩精品| 亚洲日本在线观看| 亚洲第一区色| 欧美国产精品| 亚洲乱码视频| 亚洲国产精品第一区二区三区| 久久激情视频免费观看| 国产亚洲激情在线| 久久精品国产一区二区三区免费看| 亚洲图片激情小说| 国产精品青草久久| 小黄鸭精品aⅴ导航网站入口 | 久久久久久久国产| 韩国视频理论视频久久| 麻豆精品视频在线观看| 久久婷婷综合激情| 亚洲精品色婷婷福利天堂| 亚洲黄色免费| 欧美日韩一二区| 欧美一区二区成人6969| 久久www免费人成看片高清 | 欧美一区二区黄| 亚洲自拍偷拍网址| 国产喷白浆一区二区三区| 伊人成人在线| 欧美日韩国产在线| 亚洲在线网站| 欧美中文在线观看国产| 亚洲国产另类 国产精品国产免费| 欧美成人久久| 欧美人交a欧美精品| 亚洲欧美国产精品va在线观看| 亚洲一区日本| 有码中文亚洲精品| 日韩天堂在线观看| 国产欧美精品国产国产专区| 久久资源av| 欧美三级午夜理伦三级中视频| 欧美在线三级| 欧美高清视频| 久久国内精品视频| 欧美夫妇交换俱乐部在线观看| 亚洲综合视频网| 久久人人爽国产| 亚洲一线二线三线久久久| 久久精品视频导航| 亚洲一区免费| 免费观看日韩av| 欧美一区二区视频观看视频| 欧美成在线观看| 久久夜色精品亚洲噜噜国产mv| 欧美日韩高清在线观看| 久久久国产精品一区二区中文| 欧美久久久久久久久| 久久精品国产精品亚洲| 欧美日韩成人综合| 免费欧美视频| 国产亚洲美州欧州综合国| 日韩视频免费观看| 亚洲激情av在线| 久久爱www.| 亚洲在线黄色| 欧美伦理91i| 欧美高清在线一区| 国精品一区二区三区| 亚洲天堂av图片| 9久re热视频在线精品| 久久亚洲精品网站| 久久嫩草精品久久久久| 国产精品视频一| 一区二区日韩免费看| 亚洲青涩在线| 久久在线免费视频| 免费观看一区| 在线免费高清一区二区三区| 久久精品av麻豆的观看方式| 久久国产精彩视频| 国产午夜精品久久久久久久| 一区二区三区日韩精品视频| 一本色道久久综合| 欧美日韩在线观看一区二区三区| 亚洲韩国日本中文字幕| 99精品视频一区| 欧美人妖另类| 亚洲视频免费在线观看| 亚洲综合国产激情另类一区| 欧美视频导航| 亚洲女性裸体视频| 久久久久国产精品一区二区| 黄色精品一区| 嫩草影视亚洲| 最新成人av网站| 亚洲老板91色精品久久| 一区二区日本视频| 欧美无乱码久久久免费午夜一区 | 日韩一级裸体免费视频| 男人的天堂成人在线| 亚洲国产天堂久久综合网| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲免费视频一区二区| 新67194成人永久网站| 国产毛片一区二区| 久久久久.com| 亚洲精品国产精品国自产观看| 在线视频精品一区| 国产精品国产亚洲精品看不卡15| 亚洲一区三区电影在线观看| 久久久国产成人精品| 91久久香蕉国产日韩欧美9色| 欧美日本高清视频| 亚洲在线视频网站| 麻豆9191精品国产| 一本久道久久久| 国产亚洲欧美一区二区| 久久亚洲综合色| 夜夜嗨av一区二区三区网页| 久久国产精品一区二区三区| 亚洲电影免费观看高清完整版在线观看 | 亚洲欧美国产77777| 久久乐国产精品| 亚洲精品日韩久久| 国产午夜精品久久久| 欧美全黄视频| 久久久蜜桃精品| 正在播放亚洲一区| 欧美高清视频一区二区| 欧美在线观看一二区| 亚洲伦理中文字幕| 国内外成人在线视频| 欧美色大人视频| 男女精品视频| 久久精品动漫| 亚洲一区免费视频| 99re66热这里只有精品3直播| 欧美在线免费| 亚洲网站在线播放| 亚洲人成网站999久久久综合 | 日韩网站在线| 国产真实乱偷精品视频免| 欧美日韩免费观看一区=区三区 | 久久综合色播五月| 亚洲综合成人在线| 亚洲精品乱码久久久久| 免费看的黄色欧美网站| 亚洲电影在线免费观看| 亚洲欧美日韩在线观看a三区| 最新亚洲视频|