• <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>
            Windows在加載DLL的時(shí)候,需要一個(gè)入口函數(shù),就如同控制臺(tái)或DOS程序需要main函數(shù)、WIN32程序需要WinMain函數(shù)一樣。在前面的例子中,DLL并沒(méi)有提供DllMain函數(shù),應(yīng)用工程也能成功引用DLL,這是因?yàn)閃indows在找不到DllMain的時(shí)候,系統(tǒng)會(huì)從其它運(yùn)行庫(kù)中引入一個(gè)不做任何操作的缺省DllMain函數(shù)版本,并不意味著DLL可以放棄DllMain函數(shù)。

              根據(jù)編寫(xiě)規(guī)范,Windows必須查找并執(zhí)行DLL里的DllMain函數(shù)作為加載DLL的依據(jù),它使得DLL得以保留在內(nèi)存里。這個(gè)函數(shù)并不屬于導(dǎo)出函數(shù),而是DLL的內(nèi)部函數(shù)。這意味著不能直接在應(yīng)用工程中引用DllMain函數(shù),DllMain是自動(dòng)被調(diào)用的。

              我們來(lái)看一個(gè)DllMain函數(shù)的例子(單擊此處下載本工程附件)。

            BOOL APIENTRY DllMain( HANDLE hModule,

            DWORD ul_reason_for_call,

            LPVOID lpReserved

            )

            {

            switch (ul_reason_for_call)

            {

            case DLL_PROCESS_ATTACH:

            printf("\nprocess attach of dll");

            break;

            case DLL_THREAD_ATTACH:

            printf("\nthread attach of dll");

            break;

            case DLL_THREAD_DETACH:

            printf("\nthread detach of dll");

            break;

            case DLL_PROCESS_DETACH:

            printf("\nprocess detach of dll");

            break;

            }

            return TRUE;

            }


              DllMain函數(shù)在DLL被加載和卸載時(shí)被調(diào)用,在單個(gè)線程啟動(dòng)和終止時(shí),DLLMain函數(shù)也被調(diào)用,ul_reason_for_call指明了被調(diào)用的原因。原因共有4種,即PROCESS_ATTACH、PROCESS_DETACH、THREAD_ATTACH和THREAD_DETACH,以switch語(yǔ)句列出。
            來(lái)仔細(xì)解讀一下DllMain的函數(shù)頭BOOL APIENTRY DllMain( HANDLE hModule, WORD ul_reason_for_call, LPVOID lpReserved )。

              APIENTRY被定義為_(kāi)_stdcall,它意味著這個(gè)函數(shù)以標(biāo)準(zhǔn)Pascal的方式進(jìn)行調(diào)用,也就是WINAPI方式;

              進(jìn)程中的每個(gè)DLL模塊被全局唯一的32字節(jié)的HINSTANCE句柄標(biāo)識(shí),只有在特定的進(jìn)程內(nèi)部有效,句柄代表了DLL模塊在進(jìn)程虛擬空間中的起始地址。在Win32中,HINSTANCE和HMODULE的值是相同的,這兩種類(lèi)型可以替換使用,這就是函數(shù)參數(shù)hModule的來(lái)歷。

              執(zhí)行下列代碼:

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

            if (hDll != NULL)

            {

            addFun = (lpAddFun)GetProcAddress(hDll, MAKEINTRESOURCE(1));

            //MAKEINTRESOURCE直接使用導(dǎo)出文件中的序號(hào)

            if (addFun != NULL)

            {

            int result = addFun(2, 3);

            printf("\ncall add in dll:%d", result);

            }

            FreeLibrary(hDll);

            }



              我們看到輸出順序?yàn)椋?BR>
              process attach of dll

              call add in dll:5

              process detach of dll

              這一輸出順序驗(yàn)證了DllMain被調(diào)用的時(shí)機(jī)。

              代碼中的GetProcAddress ( hDll, MAKEINTRESOURCE ( 1 ) )值得留意,它直接通過(guò).def文件中為add函數(shù)指定的順序號(hào)訪問(wèn)add函數(shù),具體體現(xiàn)在MAKEINTRESOURCE ( 1 ),MAKEINTRESOURCE是一個(gè)通過(guò)序號(hào)獲取函數(shù)名的宏,定義為(節(jié)選自winuser.h):

            #define MAKEINTRESOURCEA(i) (LPSTR)((DWORD)((WORD)(i)))

            #define MAKEINTRESOURCEW(i) (LPWSTR)((DWORD)((WORD)(i)))

            #ifdef UNICODE

            #define MAKEINTRESOURCE MAKEINTRESOURCEW

            #else

            #define MAKEINTRESOURCE MAKEINTRESOURCEA

            Posted on 2005-11-25 18:12 艾凡赫 閱讀(7639) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): DLL 技術(shù)
            欧美久久综合九色综合| 久久成人国产精品| 91精品国产高清久久久久久国产嫩草 | 久久久久亚洲AV无码专区体验| 国产A级毛片久久久精品毛片| 无码日韩人妻精品久久蜜桃| 精品免费久久久久久久| 精品免费久久久久国产一区| 久久综合亚洲色一区二区三区| 亚洲va久久久噜噜噜久久| 久久综合九色综合久99| 久久婷婷色香五月综合激情| 精品久久人妻av中文字幕| 精品无码人妻久久久久久| 伊人久久大香线蕉亚洲| 久久本道久久综合伊人| 久久偷看各类wc女厕嘘嘘| 国产69精品久久久久9999| 亚洲中文字幕久久精品无码APP| 亚洲综合久久综合激情久久 | 亚洲中文字幕久久精品无码喷水| 精品久久久久久久| 国产69精品久久久久APP下载| 亚洲国产成人久久精品影视| 大香伊人久久精品一区二区 | 亚洲va中文字幕无码久久| 99久久99久久精品国产片| 99久久国产综合精品女同图片| 久久人人爽人爽人人爽av| 久久狠狠色狠狠色综合| 亚洲中文字幕久久精品无码APP| 蜜臀久久99精品久久久久久| 99久久精品无码一区二区毛片 | 97精品依人久久久大香线蕉97| 久久久久国产一级毛片高清板| 精品久久久久久久无码| 亚洲中文久久精品无码ww16| 久久久午夜精品福利内容| 亚洲另类欧美综合久久图片区| 污污内射久久一区二区欧美日韩 | 久久精品这里热有精品|