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

            鏈接

            最新隨筆

            搜索

            最新評論

            亚洲精品高清久久| 99久久精品免费看国产一区二区三区| 亚洲精品乱码久久久久久| 亚洲国产精品一区二区久久hs| 久久热这里只有精品在线观看| 亚洲伊人久久大香线蕉苏妲己| 久久精品国产秦先生| 伊人久久大香线焦AV综合影院| 热re99久久6国产精品免费| 免费一级做a爰片久久毛片潮 | 狠狠色丁香久久综合婷婷| 99精品久久精品| 人妻丰满AV无码久久不卡| 久久精品国产亚洲一区二区| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 国产精品禁18久久久夂久| 少妇人妻综合久久中文字幕| 久久国产精品波多野结衣AV| 久久香蕉国产线看观看99| 精品久久久久久国产91| 亚洲精品国产第一综合99久久| 精品久久久无码中文字幕| 久久精品国产亚洲AV香蕉| 精品久久久无码中文字幕天天| 1000部精品久久久久久久久| 久久人人爽人人爽人人片AV麻烦 | 久久精品国产只有精品2020| 国产成人久久精品一区二区三区 | 久久久久高潮综合影院| 韩国三级中文字幕hd久久精品| 久久精品www人人爽人人| aaa级精品久久久国产片| 一本色道久久HEZYO无码| 一级女性全黄久久生活片免费 | 久久久久国产一级毛片高清板| 久久精品无码av| 国产精品免费久久久久久久久| 久久无码一区二区三区少妇 | 91精品国产91久久久久久蜜臀| 99久久无色码中文字幕| 99久久er这里只有精品18|