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

            久久人妻少妇嫩草AV蜜桃| 久久99精品久久久久久野外| 久久精品亚洲精品国产欧美| 99精品久久精品| 久久精品国产清高在天天线| 欧美精品久久久久久久自慰| 久久人人爽人人爽人人片AV东京热 | 亚洲国产精品成人AV无码久久综合影院 | 久久无码国产| 久久久久国产| 久久丝袜精品中文字幕| 亚洲欧洲久久久精品| 亚洲精品乱码久久久久久蜜桃| 性做久久久久久久久久久| 久久久久久国产a免费观看黄色大片 | 久久精品中文字幕久久| 97久久精品国产精品青草| 久久99精品国产麻豆宅宅| 久久精品国产影库免费看| 久久精品国产第一区二区| 7777精品伊人久久久大香线蕉| 77777亚洲午夜久久多喷| 久久综合狠狠综合久久综合88| 国产精品久久一区二区三区 | 精品国产乱码久久久久软件| 亚洲国产精品无码久久一线| 99久久无色码中文字幕 | 国产精品亚洲综合久久 | 精品久久久久久国产牛牛app| 久久精品国产第一区二区| 国产69精品久久久久APP下载| 色综合久久无码五十路人妻| 久久九九全国免费| 日本精品一区二区久久久| 亚洲精品乱码久久久久久自慰| 狠色狠色狠狠色综合久久| 久久香蕉国产线看观看猫咪?v| 狠狠综合久久AV一区二区三区| 日本三级久久网| 久久精品日日躁夜夜躁欧美| 久久久久四虎国产精品|