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

            11k大小
              回復  更多評論
              

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

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

            久久精品国产2020| 久久精品国产一区二区三区| 午夜精品久久久久久影视777| 久久天天躁狠狠躁夜夜2020| 人妻无码精品久久亚瑟影视| 国产成年无码久久久久毛片| 国产精品久久久久久一区二区三区| 久久综合久久综合久久综合| 亚洲精品乱码久久久久久蜜桃| 无码人妻久久一区二区三区免费| 香蕉久久一区二区不卡无毒影院| 亚洲国产成人久久综合一区77 | 思思久久99热只有频精品66| 亚洲国产精品一区二区久久hs| 久久这里只有精品久久| 久久精品日日躁夜夜躁欧美| 国内精品久久久久久中文字幕| 亚洲中文久久精品无码ww16 | 久久人人爽人人爽人人av东京热| 精品免费久久久久久久| 久久99热这里只有精品66| 久久国产热精品波多野结衣AV| 99久久这里只精品国产免费| 国产精品成人99久久久久91gav| 狠狠色丁香久久婷婷综合五月| 久久婷婷色香五月综合激情| 久久精品国产亚洲一区二区三区 | 精品免费久久久久国产一区| 精品国产福利久久久| 精品久久久久久亚洲精品| 亚洲AV无码久久精品狠狠爱浪潮| 一本色道久久88综合日韩精品 | 久久99国产精品尤物| 亚洲av成人无码久久精品| 2021国产精品午夜久久| 色综合久久中文字幕综合网| 久久久中文字幕日本| 久久久久久一区国产精品| 久久精品成人免费观看97| 久久青青草原精品国产不卡| 中文字幕无码久久久|