• <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>
            春暖花開
            雪化了,花開了,春天來了
            posts - 149,comments - 125,trackbacks - 0

            疑惑,很是疑惑的一個問題。

            下午我遇到這么一個問題,我在程序里靜態加載一個dll,這個dll是我自己寫的。我把dll在release環境下編譯,簡稱為A吧,另一個程序是在debug環境下進行編譯的,簡稱為B吧。B會調用A,但是在調用中就出錯了。

            A 中調用B的代碼如下:

            std::vector<ITEMDATA> vcData;

            GetValue(vcData);



            B 中的代碼為
               

            void GetValue(std::vector<ITEMDATA> &vcData)
            {
               ……
                ITEMDATA item;
               ……
                vcData.push_back(item);
                ……
            }

            但是程序每走完GetValue后就拋異常了。

            但是如果兩個環境都為debug,或都為release的話,都正常,但是如果不同的話,就會出錯。

            比較郁悶了。
            posted on 2009-01-05 19:16 Sandy 閱讀(2550) 評論(7)  編輯 收藏 引用 所屬分類: windows學習

            FeedBack:
            # re: 關于debug和release的一點疑惑
            2009-01-05 19:45 | windead
            release版本與debug版本所使用的runtime library是不同的,當你的DLL與程序是用不同的方式編譯后,將加載兩個不同的runtime library,因此程序會出現異常情況。
            如果一定到使用不同的編譯方式,建議DLL使用C接口。  回復  更多評論
              
            # re: 關于debug和release的一點疑惑
            2009-01-05 23:02 | 空明流轉
            樓上解釋了問題的原因。
            不過即便用C,malloc/free不用一個runtime也很容易出問題。

            跨dll的stl container通常需要自定制allocator。

            不過如果是同樣的crt可以不定制allocator。
            甚至mingw的gcc和vc的交叉調用只要用了同樣的crt也可以不定制的。
            當然也是因為mingw的stl和vc的stl很相近。

            不過這個只是特例而已。  回復  更多評論
              
            # re: 關于debug和release的一點疑惑[未登錄]
            2009-01-05 23:24 | yzzrn
            debug vector allocator與release vector allocator不是一個東西。  回復  更多評論
              
            # re: 關于debug和release的一點疑惑
            2009-01-06 01:08 | 陳梓瀚(vczh)
            因為,dll和exe的new和delete是不能跨邊界的,而且你那個是模板,所以dll和exe都有代碼。所以我建議你的dll提供allocator給exe用,否則別在接口處使用模板容器。  回復  更多評論
              
            # re: 關于debug和release的一點疑惑
            2009-01-06 08:28 | guest
            debug vector allocator與release vector allocator不是一個東西。
            --------------------------------
            同意,因為debug下,vector會包含很多調試信息,就不一樣了。  回復  更多評論
              
            # re: 關于debug和release的一點疑惑
            2009-01-06 10:29 | Sandy
            呵呵,謝謝各位指點.

            debug vector allocator與release vector allocator不是一個東西。



              回復  更多評論
              
            # re: 關于debug和release的一點疑惑
            2009-01-08 13:51 | getborn
            我原來也碰到過,最后解決方法是讓vector的分配和銷毀內存的位置在一起:

            A的調用代碼:

            std::vector<ITEMDATA>** pData;

            GetValue(&pData);


            B 中的代碼為


            void GetValue(std::vector<ITEMDATA> **pData)
            {
            ……
            ITEMDATA item;
            ……
            vcData.push_back(item); // vcData為成員變量
            (*pData) = &vcData;
            ……
            }  回復  更多評論
              
            青青草原精品99久久精品66| 四虎国产精品免费久久5151| 亚洲精品无码专区久久同性男| 三级片免费观看久久| 亚洲国产一成久久精品国产成人综合 | 亚洲精品无码久久久久去q | 97久久婷婷五月综合色d啪蜜芽 | 热re99久久精品国99热| 久久精品视频免费| 久久精品国产男包| 久久亚洲国产午夜精品理论片| 手机看片久久高清国产日韩| 精品久久久无码人妻中文字幕豆芽| 日本免费一区二区久久人人澡| 思思久久好好热精品国产| 久久精品国产半推半就| 久久久久久精品无码人妻| 久久国产成人亚洲精品影院| 性欧美丰满熟妇XXXX性久久久 | 国产无套内射久久久国产| 综合人妻久久一区二区精品| 久久国产精品波多野结衣AV| 久久99国产亚洲高清观看首页| 久久婷婷五月综合成人D啪| 精品无码人妻久久久久久| 2021少妇久久久久久久久久| 亚洲中文字幕无码久久2020| 久久婷婷五月综合97色直播| 99久久精品免费国产大片| 精品久久久久久亚洲精品| 色8久久人人97超碰香蕉987| 亚洲午夜久久久久久噜噜噜| 久久亚洲国产成人影院| 欧美精品丝袜久久久中文字幕 | 久久精品亚洲一区二区三区浴池| 超级97碰碰碰碰久久久久最新| 波多野结衣久久| 伊人久久大香线焦AV综合影院| 18岁日韩内射颜射午夜久久成人| 久久精品国产色蜜蜜麻豆| 精品熟女少妇AV免费久久|