dll加載問題的解決方法

轉自:http://blog.csdn.net/zhufangyou/article/details/6423751


dll加載問題的解決方

在使用LoadLibrary() 和LoadLibraryEx()加載dll文件的時候,會產生下面的錯誤:

this application has failed to start because XXXXX.dll was not found. Re-installing the application may fix this problem.

其中xxxxx是你所調用的dll的文件名。

這類錯誤的問題大概如下:

1.dll路徑錯誤

2. dll中又調用了其他dll文件

具體的dll加載路徑問題可以參考msdn文檔,如下:

http://msdn.microsoft.com/en-us/library/ms682586%28v=vs.85%29.aspx

注意,使用SetCurrentDirectory()設置的當前路徑加載dll文件時不可靠的。

另外可以參考下面的文章:

地址爲:

http://hi.baidu.com/jk_cau/blog/item/2e785d8fcbb804e0f11f36c6.html

問題描述:

假定EXE調用DLL,DLL內部又調用DLL1。

DLL和DLL1與EXE不在同一目錄下,而是位於一個單獨的目錄DLLDIR下。

現象:

          LoadLibrary(L"DLL");                                  加載失敗①。
           LoadLibrary(L"DLL絕對路徑");                     加載失敗②。

失敗原因:

           失敗①好理解,失敗②是因爲雖然指定了DLL絕對路徑作爲LoadLibrary的參數,但是該參數卻無法對DLL內部調用的DLL1起作用(如果把DLL1扔到EXE同級目錄下,則可以成功加載),因此無法加載的實際上是DLL1。

解決方案:

①LoadLibraryEx:

LoadLibraryEx("DLL絕對路徑", NULL, LOAD_WITH_ALTERED_SEARCH_PATH); 
通過指定LOAD_WITH_ALTERED_SEARCH_PATH,讓系統DLL搜索順序從DLL所在目錄開始。

②設置當前目錄:

         wchar_t szCurrentDir[MAX_PATH] = {0};
         ::GetCurrentDirectory(MAX_PATH, szCurrentDir);
         ::SetCurrentDirectory(strModulePath);
         HMODULE hConvertor = LoadLibrary(L"DLL絕對路徑");
        ::SetCurrentDirectory(szCurrentDir);

③SetDllDirectory:

         SetDllDirectory(L"DLL絕對路徑");
        LoadLibray(L"DLL絕對路徑");
         SetDllDirectory(NULL);                            //recover

        注:這個API與系統版本有很大依賴,不推薦使用。<=====這句話還需要驗證。

另外dll文件加載還會出現安全性問題,具體參考msdn這篇文章:

http://msdn.microsoft.com/en-us/library/ff919712%28v=VS.85%29.aspx

裏面用到的process monitor調試非常有用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章