• <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++技術 在這里寫下自己的學習心得 感悟 和大家討論 共同進步(歡迎批評?。。。?/p>

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

            公告

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

            常用鏈接

            留言簿(19)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 387834
            • 排名 - 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 @王一偉 閱讀(5390) 評論(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久久久精品无码| 国产精品一区二区久久国产| 93精91精品国产综合久久香蕉 | 青青青青久久精品国产 | 99精品久久久久久久婷婷| 理论片午午伦夜理片久久| 久久夜色精品国产网站| 久久影院午夜理论片无码| 东京热TOKYO综合久久精品| 久久久久亚洲精品中文字幕| 国内精品久久久久久久97牛牛| 久久久精品波多野结衣| 97久久国产亚洲精品超碰热| 伊人久久大香线蕉无码麻豆| 色噜噜狠狠先锋影音久久| 亚洲中文久久精品无码ww16| 久久国产免费| 久久亚洲高清观看| 久久精品www人人爽人人| 亚洲人AV永久一区二区三区久久| 97久久天天综合色天天综合色hd| 亚洲精品无码久久久| 国产成人精品久久亚洲| 久久精品国产亚洲麻豆| 无码国内精品久久人妻| 久久精品国产亚洲AV影院| 亚洲?V乱码久久精品蜜桃| 久久久久亚洲AV综合波多野结衣| 一本久久久久久久| 国产精品久久久久久久久久免费| 久久综合中文字幕| 伊人久久大香线焦综合四虎| 韩国三级大全久久网站| 久久久久久免费一区二区三区| 国产精品对白刺激久久久| 国产情侣久久久久aⅴ免费| 国产精品女同久久久久电影院| 久久亚洲私人国产精品vA |