• <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://m.shnenglu.com/Files/sunraiing9/hahahah.rar

            11k大小
              回復  更多評論
              

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

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

            97久久超碰成人精品网站| 丰满少妇人妻久久久久久| 99麻豆久久久国产精品免费 | 久久精品国产半推半就| 久久91精品综合国产首页| 一本久久a久久精品综合香蕉| 久久久无码精品亚洲日韩蜜臀浪潮| 一级做a爰片久久毛片人呢| 无码人妻久久一区二区三区蜜桃| 久久久精品国产sm调教网站| 久久免费高清视频| 国产成人久久AV免费| 久久99久久无码毛片一区二区| 一本色综合网久久| 久久综合色老色| 欧美国产成人久久精品| 国内精品久久久久久久久电影网| 伊人久久一区二区三区无码| 久久国产精品久久精品国产| 久久久久免费精品国产| 99久久国产宗和精品1上映| 狠狠久久综合伊人不卡| 久久无码人妻一区二区三区| 综合人妻久久一区二区精品| 国产真实乱对白精彩久久| 国产情侣久久久久aⅴ免费| 久久精品成人欧美大片| 日韩中文久久| 午夜视频久久久久一区 | 国产精品欧美亚洲韩国日本久久 | 伊人色综合久久天天人手人婷| 久久综合九色综合久99| 人妻丰满AV无码久久不卡| 香蕉aa三级久久毛片 | 亚洲精品乱码久久久久久按摩| 中文精品久久久久人妻不卡| 日韩欧美亚洲综合久久影院Ds| 国产91久久综合| 久久久久亚洲AV成人网| 国产精品久久久久久久久软件| 亚洲精品无码久久久久sm|