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

            天下

            記錄修行的印記

            動態鏈接庫(1)

            extern "C" int add(int x,int y);   //聲明為 按照C語言方式編譯和連接

            動態鏈接庫
            DLL(Dynamic Linkable Library)
            __declspec(dllimport)   聲明一個導入函數,一般用于使用某個dll的 應用程序
            __declspec(dllexport)   聲明一個導出函數,一般用于該dll中

            __declspec(dllexport)

            聲明一個導出函數,是說這個函數要從本DLL導出。我要給別人用。一般用于dll中
            省掉在DEF文件中手工定義導出哪些函數的一個方法。當然,如果你的DLL里全是C++的類的話,你無法在DEF里指定導出的函數,只能用__declspec(dllexport)導出類

            __declspec(dllimport)

            聲明一個導入函數,是說這個函數是從別的DLL導入。我要用。一般用于使用某個dll的exe中,
            不使用 __declspec(dllimport) 也能正確編譯代碼,但使用 __declspec(dllimport) 使編譯器可以生成更好的代碼。編譯器之所以能夠生成更好的代碼,是因為它可以確定函數是否存在于 DLL 中,這使得編譯器可以生成跳過間接尋址級別的代碼,而這些代碼通常會出現在跨 DLL 邊界的函數調用中。但是,必須使用 __declspec(dllimport) 才能導入 DLL 中使用的變量。



            DLL的調用方式

              由LoadLibrary()、GetProcAddress()、FreeLibrary()系統Api提供的三位一體“DLL加載
            -DLL函數地址獲取-DLL釋放”方式,這種調用方式稱為DLL的動態調用。

              下面我們來看看靜態調用的例子(單擊此處下載本工程附件),將編譯dllTest工程所生成的.lib和.dll文件拷入dllCall工程所在的路徑,dllCall執行下列代碼:
            #pragma comment(lib,
            "dllTest.lib")
            //.lib文件中僅僅是關于其對應DLL文件中函數的重定位信息

            extern "C" __declspec(dllimport) add(int x,int y);
            int main(int argc, char* argv[])
            {
                
            int result = add(2,3);
                printf(
            "%d",result);
                
            return 0;
            }

            由上述代碼可以看出,靜態調用方式的順利進行需要完成兩個動作:

            (
            1)告訴編譯器與DLL相對應的.lib文件所在的路徑及文件名,#pragma comment(lib,"dllTest.lib")就是起這個作用。

            程序員在建立一個DLL文件時,連接器會自動為其生成一個對應的.lib文件,該文件包含了DLL 導出函數的符號名及序號(并不含有實際的代碼)。在應用程序里,.lib文件將作為DLL的替代文件參與編譯。

            (
            2)聲明導入函數,extern "C" __declspec(dllimport) add(int x,int y)語句中的__declspec(dllimport)發揮這個作用。

            靜態調用方式不再需要使用系統API來加載、卸載DLL以及獲取DLL中導出函數的地址。這是因為,當程序員通過靜態鏈接方式編譯生成應用程序時,應用程序中調用的與.lib文件中導出符號相匹配的函數符號將進入到生成的EXE 文件中,.lib文件中所包含的與之對應的DLL文件的文件名也被編譯器存儲在 EXE文件內部。當應用程序運行過程中需要加載DLL文件時,Windows將根據這些信息發現并加載DLL,然后通過符號名實現對DLL 函數的動態鏈接。這樣,EXE將能直接通過函數名調用DLL的輸出函數,就象調用程序內部的其他函數一樣。


            如果通過VC
            ++編寫的DLL欲被其他語言編寫的程序調用,應將函數的調用方式聲明為__stdcall方式,WINAPI都采用這種方式,而C/C++缺省的調用方式卻為__cdecl。

            posted on 2011-03-14 10:34 天下 閱讀(353) 評論(0)  編輯 收藏 引用 所屬分類: Win32

            <2012年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            久久天天躁狠狠躁夜夜av浪潮| 伊人久久大香线蕉影院95| 狠狠精品久久久无码中文字幕 | 久久夜色精品国产噜噜麻豆| 久久国产乱子伦免费精品| 精品国产乱码久久久久久浪潮| 国内精品久久久久久不卡影院| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久久久18| 久久亚洲日韩看片无码| 国产精品美女久久久久久2018| 久久99精品久久久久久齐齐| 伊人久久大香线蕉综合热线| 66精品综合久久久久久久| 久久综合久久伊人| 狠狠狠色丁香婷婷综合久久五月| 久久久久久久久久久| 久久人人爽人人澡人人高潮AV | 99久久国产宗和精品1上映| 久久伊人中文无码| 久久精品aⅴ无码中文字字幕重口| 精品熟女少妇aⅴ免费久久| 漂亮人妻被黑人久久精品| 久久亚洲中文字幕精品一区四| 久久精品亚洲一区二区三区浴池| 日本久久中文字幕| 爱做久久久久久| 欧美日韩精品久久久久| 国产99久久久国产精品~~牛| 久久精品国产亚洲αv忘忧草 | 中文字幕无码久久精品青草| 久久精品极品盛宴观看| 免费国产99久久久香蕉| 久久亚洲国产成人精品无码区| 国产99久久精品一区二区| yellow中文字幕久久网| 99精品久久精品一区二区| 漂亮人妻被黑人久久精品| 久久久久无码精品国产| 精品久久久久久国产潘金莲| 久久亚洲精品无码AV红樱桃|