• <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 閱讀(993) 評論(0)  編輯 收藏 引用 所屬分類: [再轉]
            函數功能描述:GetProcAddress函數檢索指定的動態(tài)鏈接庫(DLL)中的輸出庫函數地址。

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

            參數:
            hModule
               [in] 包含此函數的DLL模塊的句柄。LoadLibrary或者GetModuleHandle函數可以返回此句柄。
            lpProcName
               [in] 包含函數名的以NULL結尾的字符串,或者指定函數的序數值。如果此參數是一個序數值,它必須在一個字的底字節(jié),高字節(jié)必須為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 文件不連續(xù)地定義函數的序數值,如從1到N(N是輸出的函數序數值),錯誤將會發(fā)生,GetProcAddress將會返回一個錯誤的、非空的地址,雖然 指定的序數沒有對應的函數。
               為了防止函數不存在,函數應該通過名字指定而不是序數值。

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

            參看:
            動態(tài)鏈接庫縱覽(Dynamic-Link Libraries Overview), 動態(tài)鏈接庫函數(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

            亚洲日韩中文无码久久| 秋霞久久国产精品电影院| 午夜视频久久久久一区 | 亚洲精品无码专区久久同性男| 久久se精品一区精品二区国产 | 久久美女人爽女人爽| 国产激情久久久久影院小草| 亚洲精品NV久久久久久久久久 | 一本久久a久久精品vr综合| 久久w5ww成w人免费| 久久九九久精品国产免费直播| 久久精品国产久精国产果冻传媒| 国产V综合V亚洲欧美久久| 日本久久久久久久久久| 精品国际久久久久999波多野| 久久性精品| 狠狠人妻久久久久久综合| 久久综合给久久狠狠97色| 亚洲精品WWW久久久久久| 久久久久久久99精品免费观看| 丁香色欲久久久久久综合网| 狠狠精品久久久无码中文字幕| 国产精品美女久久久久久2018| 国产香蕉久久精品综合网| 久久久久久亚洲精品无码| 99久久99久久久精品齐齐| 无码精品久久久久久人妻中字| 亚洲人成无码网站久久99热国产| 99久久99久久精品国产片果冻| 97久久久久人妻精品专区| 久久久久亚洲AV成人网人人网站 | 久久久久亚洲av综合波多野结衣 | 99久久99这里只有免费费精品| 99久久做夜夜爱天天做精品| 免费一级欧美大片久久网| 久久人人爽人爽人人爽av| 国产成人精品久久亚洲| 久久天天躁狠狠躁夜夜2020老熟妇| 精品久久久久久国产三级| 久久www免费人成看国产片 | 欧美亚洲色综久久精品国产|