在使用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調試非常有用。