• <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>
            DLL定義的全局變量可以被調用進程訪問;DLL也可以訪問調用進程的全局數據,我們來看看在應用工程中引用DLL中變量的例子(單擊此處下載本工程附件)。

            /* 文件名:lib.h */

            #ifndef LIB_H

            #define LIB_H

            extern int dllGlobalVar;

            #endif


            /* 文件名:lib.cpp */

            #include "lib.h"

            #include <windows.h>


            int dllGlobalVar;


            BOOL APIENTRY DllMain(HANDLE hModule, DWORD ul_reason_for_call, LPVOID lpReserved)

            {

            switch (ul_reason_for_call)

            {

            case DLL_PROCESS_ATTACH:

            dllGlobalVar = 100; //在dll被加載時,賦全局變量為100

            break;

            case DLL_THREAD_ATTACH:

            case DLL_THREAD_DETACH:

            case DLL_PROCESS_DETACH:

            break;

            }

            return TRUE;

            }


            ;文件名:lib.def

            ;在DLL中導出變量

            LIBRARY "dllTest"

            EXPORTS

            dllGlobalVar CONSTANT

            ;或dllGlobalVar DATA

            GetGlobalVar


              從lib.h和lib.cpp中可以看出,全局變量在DLL中的定義和使用方法與一般的程序設計是一樣的。若要導出某全局變量,我們需要在.def文件的EXPORTS后添加:

            變量名 CONSTANT   //過時的方法


              或

            變量名 DATA     //VC++提示的新方法

            在主函數中引用DLL中定義的全局變量:

            #include <stdio.h>

            #pragma comment(lib,"dllTest.lib")

            extern int dllGlobalVar;

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

            {

            printf("%d ", *(int*)dllGlobalVar);

            *(int*)dllGlobalVar = 1;

            printf("%d ", *(int*)dllGlobalVar);


            return 0;

            }


              特別要注意的是用extern int dllGlobalVar聲明所導入的并不是DLL中全局變量本身,而是其地址,應用程序必須通過強制指針轉換來使用DLL中的全局變量。這一點,從*(int*)dllGlobalVar可以看出。因此在采用這種方式引用DLL全局變量時,千萬不要進行這樣的賦值操作:

            dllGlobalVar = 1;


              其結果是dllGlobalVar指針的內容發生變化,程序中以后再也引用不到DLL中的全局變量了。

              在應用工程中引用DLL中全局變量的一個更好方法是:

            #include <stdio.h>

            #pragma comment(lib,"dllTest.lib")

            extern int _declspec(dllimport) dllGlobalVar; //用_declspec(dllimport)導入

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

            {

            printf("%d ", dllGlobalVar);

            dllGlobalVar = 1; //這里就可以直接使用, 無須進行強制指針轉換

            printf("%d ", dllGlobalVar);

            return 0;

            }


              通過_declspec(dllimport)方式導入的就是DLL中全局變量本身而不再是其地址了,筆者建議在一切可能的情況下都使用這種方式。

            Posted on 2005-11-25 18:21 艾凡赫 閱讀(7045) 評論(0)  編輯 收藏 引用 所屬分類: DLL 技術
            性做久久久久久免费观看| 午夜精品久久久久久中宇| 99久久无色码中文字幕人妻| 精品久久久久久国产三级| 韩国免费A级毛片久久| 亚洲精品无码专区久久久| 亚洲国产精品嫩草影院久久| 精品无码久久久久久久久久| 亚洲国产精品久久久久婷婷老年| 久久精品国产一区二区三区日韩| 久久香蕉国产线看观看精品yw| 日产精品99久久久久久| 国产毛片欧美毛片久久久| 国产精品中文久久久久久久| 久久人人爽人人人人片av| 一本一本久久A久久综合精品| 久久久久亚洲精品日久生情| 欧美日韩精品久久免费| 亚洲伊人久久大香线蕉综合图片| 久久精品国产日本波多野结衣| 中文字幕无码久久精品青草| 亚洲综合熟女久久久30p| 久久夜色精品国产欧美乱| 精品久久香蕉国产线看观看亚洲| 伊人久久综在合线亚洲2019| 久久精品亚洲男人的天堂| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 91久久精一区二区三区大全| 国产欧美久久久精品| 久久99热这里只有精品国产| 国产精品亚洲综合久久 | 日本精品久久久久中文字幕8| 国产三级精品久久| 中文精品久久久久人妻| 国产精品99精品久久免费| 久久精品国产亚洲AV不卡| 中文字幕乱码久久午夜| 中文字幕久久欲求不满| 亚洲精品无码久久久久去q| 91秦先生久久久久久久| 久久精品国产亚洲av麻豆图片|