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

            GetProcAddress函數

            Posted on 2008-07-24 20:43 RichardHe 閱讀(1008) 評論(0)  編輯 收藏 引用 所屬分類: [再轉]
            函數功能描述:GetProcAddress函數檢索指定的動態鏈接庫(DLL)中的輸出庫函數地址。

            函數原型:
            FARPROC GetProcAddress(
               HMODULE hModule,     // DLL模塊句柄
               LPCSTR lpProcName    // 函數名
            );

            參數:
            hModule
               [in] 包含此函數的DLL模塊的句柄。LoadLibrary或者GetModuleHandle函數可以返回此句柄。
            lpProcName
               [in] 包含函數名的以NULL結尾的字符串,或者指定函數的序數值。如果此參數是一個序數值,它必須在一個字的底字節,高字節必須為0。
              
            返回值:
               如果函數調用成功,返回值是DLL中的輸出函數地址。
               如果函數調用失敗,返回值是NULL。得到進一步的錯誤信息,調用函數GetLastError。

            注釋:
               GetProcAddress函數被用來檢索在DLL中的輸出函數地址。
               lpProcName指針指向的函數名,拼寫和大小寫必須和DLL源代碼中的模塊定義文件(.DEF)中輸出段(EXPORTS)中指定的相同。 Win32 API函數的輸出名可能不同于你在代碼中調用的這些函數名,這個不同被宏隱含在相關的SDK頭文件中。如果想得到更多信息,請參考Win32函數原型 (Win32 Function Prototypes)。
               lpProcName參數能夠識別DLL中的函數,通過指定一個與函數相聯系的序數值(在.DEF中的EXPORTS段)。GetProcAddress 函數驗證那個指定的序數值是否在輸出的序數1和最高序數值之間(在.DEF中)。函數用這個序數值作為索引從函數表中讀函數地址,假如.DEF 文件不連續地定義函數的序數值,如從1到N(N是輸出的函數序數值),錯誤將會發生,GetProcAddress將會返回一個錯誤的、非空的地址,雖然 指定的序數沒有對應的函數。
               為了防止函數不存在,函數應該通過名字指定而不是序數值。

            要求:
               Windows NT/2000: 要求Windows NT 3.1 或以后版本。
               Windows 95/98: 要求Windows 95 或以后版本。
               頭文件: 在Winbase.h中聲明,include Windows.h。
               庫文件: Use Kernel32.lib。

            參看:
            動態鏈接庫縱覽(Dynamic-Link Libraries Overview), 動態鏈接庫函數(Dynamic-Link Library Functions),FreeLibrary, GetModuleHandle, LoadLibrary

            示例代碼:

               調用KERNEL32.DLL中的RegisterServiceProcess(僅在Windows98中適用)

               HMODULE hModule=GetModuleHandle("kernel32.dll");
               if (hModule)
               {
                  typedef DWORD (CALLBACK *LPFNREGISTER)(DWORD,DWORD);
                  LPFNREGISTER lpfnRegister;
                  lpfnRegister=(LPFNREGISTER)GetProcAddress(hModule,"RegisterServiceProcess");
                  if (lpfnRegister)
                  {
                    (*lpfnRegister)(NULL,1L);
                  }
               }

            posts - 94, comments - 138, trackbacks - 0, articles - 94

            Copyright © RichardHe

            色婷婷综合久久久久中文字幕| 精品久久久久久| 亚洲国产成人久久精品影视| 久久久国产打桩机| 无码任你躁久久久久久老妇| 青青青青久久精品国产h| 久久精品无码午夜福利理论片| 少妇熟女久久综合网色欲| 亚洲精品WWW久久久久久| 久久久WWW成人免费精品| 久久精品这里只有精99品| 三级片免费观看久久| 中文精品99久久国产| 久久国产精品无| 18禁黄久久久AAA片| 久久精品蜜芽亚洲国产AV| av无码久久久久久不卡网站| 狠狠久久亚洲欧美专区| 青青国产成人久久91网| 久久国产免费直播| 97视频久久久| 色综合久久久久综合体桃花网| 亚洲午夜久久久久妓女影院| 久久99精品国产自在现线小黄鸭| 久久亚洲欧美日本精品| 久久夜色撩人精品国产小说| 久久人人爽人人人人爽AV| 一本色道久久HEZYO无码| 久久综合丁香激情久久| 亚洲国产精品狼友中文久久久| 亚洲va国产va天堂va久久| 国产精品9999久久久久| 欧美久久天天综合香蕉伊| 午夜欧美精品久久久久久久| 97精品国产97久久久久久免费| 亚洲国产日韩欧美久久| 国产V综合V亚洲欧美久久| 亚洲国产精品无码久久青草| www.久久99| 囯产精品久久久久久久久蜜桃| 国产成人久久久精品二区三区|