• <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>

            積木

            No sub title

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            原諒轉載自:http://lukas06.blog.sohu.com/94010246.html

                C++編譯器在生成DLL時,會對導出函數進行名字改編,并且不同的編譯器使用的改編規則不一樣,因此改編的名字后的名字是不一樣的。因此,如果利用不同的分別生成DLL文件和訪問DLL文件的客戶端,那么后者在訪問該DLL文件的時候就會出現問題。例如:使用C++編寫了一個DLL,而使用C語言編寫的客戶端進行訪問就會出現問題。由于C++編譯器已經對該導出函數名字進行了改編,所以用C語言編寫的客戶端就找不到DLL的導出函數。這就是DLL導出函數的名字改編問題。

                如果希望動態鏈接庫文件在編譯時,導出函數的名稱不要發生改變,那么在定義導出函數時,需要加上限定符:extern "C"。注意:雙引號中的“C”一定要大寫。

            例如:Dll1.h頭文件
            #ifdef DLL1_API
            #else
            #define DLL1_API extern "C" _declspec(dllimport)
            #endif

            DLL1_API int add(int a,int b);
            DLL1_API int subtract(int a,int b);

            Dll1.cpp源文件
            #define DLL1_API extern "C" _declspec(dllexport)
            #include "Dll1.h"

            int add(int a,int b)
            {
                return a+b;
            }
            int subtract(int a,int b)
            {
                return a-b;
            }
            這樣利用dumpbin工具可以查看Dll2.dll的導出函數,>dumpbin -exports Dll2.dll,可以發現名字沒有被改編。

            利用限定符extern "C"可以解決C++和C語言之間相互調用時函數命名的問題。但是這種方法有一個缺陷:就是不能用于導出一個類的成員函數,而只能用于導出全局函數這種情況。

            但是還有一個問題是,如果使用了標準調用約定,也就是pascal調用約定,WINAPI調用約定:_stdcall,此時即使使用了extern "C",仍然會出現導出函數名字被改編的問題。例如:使用C語言編寫一個DLL文件,而客戶端使用Delphi進行編寫,那么在編寫導出函數時,應該指定其使用標準的函數調用約定。此時,就會出現問題,即C語言編寫的DLL文件的導出函數發生了名字改編。在這種情況下,可以使用一個稱為模塊定義文件(DEF)的方式解決名字改編問題。
            例如:Dll2.def
            LIBRARY

            EXPORTS
            add
            subtract
            如果想使用與源文件中定義的不一樣的函數名,可以按照以下語法:entryname=internalname
            其中,entryname是要導出的符號名,而internalname是DLL中將要導出的函數名。

            示例:

            LIBRARY "VerifyLocalResType"

            EXPORTS

                    VerifyDDSSize
                    VerifyDDSType
                    VerifyTGASize
                    VerifyTGAType

             

            posted on 2011-11-26 16:03 Jacc.Kim 閱讀(2361) 評論(1)  編輯 收藏 引用 所屬分類: VC / C++

            Feedback

            # re: 解決DLL導出函數的名字改編問題 2011-12-28 20:12 Tan chee seng
            DLL 函數譯碼軟仵  回復  更多評論
              

            久久九色综合九色99伊人| 亚洲精品tv久久久久久久久久| 久久精品国产AV一区二区三区| 中文字幕热久久久久久久| 精品久久久噜噜噜久久久 | 久久国产欧美日韩精品| 99久久精品日本一区二区免费 | 伊人久久大香线蕉综合热线| AV无码久久久久不卡蜜桃| MM131亚洲国产美女久久| 狠狠人妻久久久久久综合| 久久99精品国产麻豆宅宅| 狠狠色综合网站久久久久久久| 囯产极品美女高潮无套久久久| 91久久香蕉国产熟女线看| 一本一本久久A久久综合精品| 国产精品熟女福利久久AV| 久久国产色AV免费观看| 亚洲国产香蕉人人爽成AV片久久| 久久国产乱子精品免费女| 亚洲色欲久久久综合网东京热| 久久久久无码中| 国产成人精品久久综合| 狠狠色丁香久久综合五月| 久久综合狠狠综合久久综合88| 国产精品成人久久久| 久久久久亚洲精品男人的天堂 | 久久se精品一区精品二区| 久久精品国产亚洲AV久| 欧美亚洲日本久久精品| 久久精品综合一区二区三区| AA级片免费看视频久久| 狠狠色婷婷综合天天久久丁香| 欧美午夜精品久久久久免费视| 亚洲欧美日韩精品久久亚洲区| 久久久久99精品成人片| 精品久久久久久久久久中文字幕 | 国产精品9999久久久久| 日韩乱码人妻无码中文字幕久久| 中文精品久久久久人妻不卡| 国产成人无码精品久久久性色 |