GetProcAddress函數


函數功能描述: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);
      }
   }

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM