• <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>
            在建立的工程中添加lib.h及lib.cpp文件,源代碼如下:

            /* 文件名:lib.h */

            #ifndef LIB_H

            #define LIB_H

            extern "C" int __declspec(dllexport)add(int x, int y);

            #endif


            /* 文件名:lib.cpp */

            #include "lib.h"

            int add(int x, int y)

            {

            return x + y;

            }

            分析上述代碼,dllTest工程中的lib.cpp文件與第2節靜態鏈接庫版本完全相同,不同在于lib.h對函數add的聲明前面添加了__declspec(dllexport)語句。這個語句的含義是聲明函數add為DLL的導出函數。DLL內的函數分為兩種:

              (1)DLL導出函數,可供應用程序調用;

              (2) DLL內部函數,只能在DLL程序使用,應用程序無法調用它們。

            與第2節對靜態鏈接庫的調用相似,我們也建立一個與DLL工程處于同一工作區的應用工程dllCall,它調用DLL中的函數add,其源代碼如下:

            #include <stdio.h>

            #include <windows.h>

            typedef int(*lpAddFun)(int, int); //宏定義函數指針類型

            int main(int argc, char *argv[])

            {

            HINSTANCE hDll; //DLL句柄

            lpAddFun addFun; //函數指針

            hDll = LoadLibrary("..\\Debug\\dllTest.dll");

            if (hDll != NULL)

            {

            addFun = (lpAddFun)GetProcAddress(hDll, "add");

            if (addFun != NULL)

            {

            int result = addFun(2, 3);

            printf("%d", result);

            }

            FreeLibrary(hDll);

            }

            return 0;

            }
            而應用程序對本DLL的調用和對第2節靜態鏈接庫的調用卻有較大差異,下面我們來逐一分析。

              首先,語句typedef int ( * lpAddFun)(int,int)定義了一個與add函數接受參數類型和返回值均相同的函數指針類型。隨后,在main函數中定義了lpAddFun的實例addFun;

              其次,在函數main中定義了一個DLL HINSTANCE句柄實例hDll,通過Win32 Api函數LoadLibrary動態加載了DLL模塊并將DLL模塊句柄賦給了hDll;

              再次,在函數main中通過Win32 Api函數GetProcAddress得到了所加載DLL模塊中函數add的地址并賦給了addFun。經由函數指針addFun進行了對DLL中add函數的調用;

              最后,應用工程使用完DLL后,在函數main中通過Win32 Api函數FreeLibrary釋放了已經加載的DLL模塊。

              通過這個簡單的例子,我們獲知DLL定義和調用的一般概念:

              (1)DLL中需以某種特定的方式聲明導出函數(或變量、類);

              (2)應用工程需以某種特定的方式調用DLL的導出函數(或變量、類)。

            Posted on 2005-11-25 17:58 艾凡赫 閱讀(951) 評論(1)  編輯 收藏 引用 所屬分類: DLL 技術

            Feedback

            # re: 非MFC DLL  回復  更多評論   

            2008-09-17 00:15 by 愛飯盒
            存在繼承時:

            #ifdef __DLL_BUILD
            class _declspec(dllexport) CA;
            #else
            class _declspec(dllimport) CA;
            #endif
            class CA
            {
            public:
            CA();
            };

            #ifdef __DLL_BUILD
            class _declspec(dllexport) CB;
            #else
            class _declspec(dllimport) CB;
            #endif
            class CB:public CA
            {
            public:
            CB();
            };

            精品久久久久中文字幕日本| 综合久久给合久久狠狠狠97色 | 久久午夜电影网| 91精品国产综合久久四虎久久无码一级 | 亚洲色欲久久久综合网东京热 | 久久久久亚洲AV无码专区网站| 一97日本道伊人久久综合影院| 国产精品乱码久久久久久软件| 国产69精品久久久久777| 合区精品久久久中文字幕一区 | 久久99精品国产99久久| 久久天天日天天操综合伊人av| 久久综合给合久久狠狠狠97色| 久久亚洲国产午夜精品理论片 | 亚洲香蕉网久久综合影视| 久久福利青草精品资源站| 漂亮人妻被中出中文字幕久久 | 久久成人影院精品777| 久久综合亚洲鲁鲁五月天| 九九久久自然熟的香蕉图片| 国产高潮久久免费观看| 久久男人Av资源网站无码软件| 久久国产V一级毛多内射| 国产一区二区三区久久精品| 色播久久人人爽人人爽人人片AV| 国产精品美女久久久久网| 亚洲国产精品高清久久久| 国产精品久久久香蕉| 久久精品国产一区二区电影| 久久久久国产一级毛片高清版| 久久精品亚洲中文字幕无码麻豆| 中文成人久久久久影院免费观看| 久久最近最新中文字幕大全 | 久久久无码精品亚洲日韩按摩| 亚洲国产成人久久综合一区77| 久久国产福利免费| 国产叼嘿久久精品久久| 97久久久久人妻精品专区 | 久久久精品国产sm调教网站| 久久受www免费人成_看片中文| 亚洲AⅤ优女AV综合久久久|