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

            醬壇子

            專注C++技術 在這里寫下自己的學習心得 感悟 和大家討論 共同進步(歡迎批評!!!)

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              66 Posts :: 16 Stories :: 236 Comments :: 0 Trackbacks

            公告

            王一偉 湖南商學院畢業 電子信息工程專業

            常用鏈接

            留言簿(19)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 387045
            • 排名 - 64

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            Visual C++
            GetProcAddress
            顯式鏈接到 DLL 的進程調用 GetProcAddress 來獲取 DLL 導出函數的地址。使用返回的函數指針調用 DLL 函數。GetProcAddress 將(由 LoadLibraryAfxLoadLibraryGetModuleHandle 返回的)DLL 模塊句柄和要調用的函數名或函數的導出序號用作參數。

            由于是通過指針調用 DLL 函數并且沒有編譯時類型檢查,需確保函數的參數是正確的,以便不會超出在堆棧上分配的內存和不會導致訪問沖突。幫助提供類型安全的一種方法是查看導出函數的函數原型,并創建函數指針的匹配 typedef。例如:

            typedef UINT (CALLBACK* LPFNDLLFUNC1)(DWORD,UINT);


            HINSTANCE hDLL;               
            // Handle to DLL
            LPFNDLLFUNC1 lpfnDllFunc1;    // Function pointer
            DWORD dwParam1;
            UINT  uParam2
            , uReturnVal;

            hDLL 
            = LoadLibrary("MyDLL");
            if (hDLL != NULL)
            {
               lpfnDllFunc1 
            = (LPFNDLLFUNC1)GetProcAddress(hDLL,
                                                       
            "DLLFunc1");
               
            if (!lpfnDllFunc1)
               {
                  
            // handle the error
                  FreeLibrary(hDLL);
                  
            return SOME_ERROR_CODE;
               }
               
            else
               {
                  
            // call the function
                  uReturnVal = lpfnDllFunc1(dwParam1, uParam2);
               }
            }

            調用 GetProcAddress 時指定所需函數的方式取決于 DLL 的生成方式。

            僅當要鏈接到的 DLL 是用模塊定義 (.def) 文件生成的,并且序號在 DLL 的 .def 文件的 EXPORTS 部分中與函數一起列出時,才能獲取導出序號。如果 DLL 具有許多導出函數,則相對于使用函數名,使用導出序號調用 GetProcAddress 的速度稍快一些,因為導出序號是 DLL 導出表的索引。使用導出序號,GetProcAddress 可直接定位函數,而不是將指定名稱與 DLL 導出表中的函數名進行比較。但是,僅當有權控制 .def 文件中導出函數的序號分配時,才應使用導出序號調用 GetProcAddress

             


            posted on 2007-08-08 23:00 @王一偉 閱讀(5376) 評論(3)  編輯 收藏 引用

            Feedback

            # re: GetProcAddress 2007-08-09 08:58 @王一偉
            我重新寫了上面的代碼 發覺還是有問題dll能導入成功,函數地址能獲取

            但是一旦用typedef的函數指針的時候就連編譯都編譯不過了

            請求幫助

            工程文件如下http://www.shnenglu.com/Files/sunraiing9/hahahah.rar

            11k大小
              回復  更多評論
              

            # re: GetProcAddress 2007-08-09 09:50 @王一偉
            已經解決 嘿嘿  回復  更多評論
              

            # re: GetProcAddress 2010-04-29 17:32 jocy
            3Q
              回復  更多評論
              

            狠狠色噜噜狠狠狠狠狠色综合久久| 久久久久国产精品三级网| 精品国产99久久久久久麻豆| 久久www免费人成看片| 久久精品aⅴ无码中文字字幕不卡| 久久精品免费观看| 2020国产成人久久精品| 精品久久久久久中文字幕| 亚洲а∨天堂久久精品| 久久91精品国产91久久户| 久久久亚洲AV波多野结衣| 免费观看久久精彩视频| 国产精品久久久久久久久久影院| 久久99精品国产麻豆宅宅| 久久国产亚洲精品| 国产成人精品久久一区二区三区av | 国产精品久久久久aaaa| 亚洲国产高清精品线久久| 久久这里只有精品首页| 日韩精品久久久久久免费| 亚洲乱码日产精品a级毛片久久| 久久久久人妻一区二区三区vr | 久久久久黑人强伦姧人妻| 久久精品亚洲日本波多野结衣 | 日韩影院久久| 久久久久亚洲AV无码专区网站| 久久天天躁狠狠躁夜夜2020一| 精品久久久久久国产| 久久综合88熟人妻| 久久久婷婷五月亚洲97号色 | 一本久久精品一区二区| 国产成人久久777777| 久久久久夜夜夜精品国产| 精品国产一区二区三区久久| 国内精品伊人久久久久AV影院| 欧美牲交A欧牲交aⅴ久久| 婷婷久久久亚洲欧洲日产国码AV | 99精品国产免费久久久久久下载 | 久久久久亚洲AV片无码下载蜜桃 | 久久久亚洲欧洲日产国码aⅴ| 热99RE久久精品这里都是精品免费 |