VC++ loadlibrary()加載三方dll失敗, 返回錯誤碼:126的解決方法
方式一: 采用 LoadLibraryEx
若DLL不在調用方的同一目錄下,可以用LoadLibrary(L”DLL絕對路徑”)加載。但若調用的DLL內部又調用另外一個DLL,此時調用仍會失敗。解決辦法是用LoadLibraryEx:
LoadLibraryEx(“DLL絕對路徑”, NULL, LOAD_WITH_ALTERED_SEARCH_PATH);
通過指定LOAD_WITH_ALTERED_SEARCH_PATH,讓系統DLL搜索順序從DLL所在目錄開始。
方式二: 采用 SetCurrentDir
跨目錄調用dll,你應該這樣
- 用GetCurrentDir保存當前的工作目錄
- 用SetCurrentDir將當前的工作目錄,設置為你的DLL所在的路徑,需要使用絕對路徑
- 用LoadLibrary你的DLL
- 使用SetCurrentDir恢復到原來的工作路徑
如下所示
TCHAR chCurDir[MAX_PATH] = {0}; GetCurrentDirectory(MAX_PATH, chCurDir); SetCurrentDirectory(_T("E:\\test\\")); m_hDLL = LoadLibrary(_T("MyTest.dll")); SetCurrentDirectory(chCurDir);
dll的加載順序
- EXE所在目錄;
- 當前目錄GetCurrentDirectory();
- 系統目錄GetSystemDirectory();
- WINDOWS目錄GetWindowsDirectory();
- 環境變量 PATH 所包含的目錄。
使用loadlibrary加載dll使用的路徑時,這個函數會忽略這個路徑,隻會按既定規則加載dll。所以如果要加載指定目錄的dll,可以用上述兩個解決方案。
後續
最近又遇到一個126的問題, 采用上述兩種方式依然無法解決
問題描述:
Windows 64位系統, 加載32位dll, DLL加載路徑為 “C:\Windows\System32\xxx.dll”
解決辦法:
將上述加載失敗的DLL, 復制一份到”C:\Windows\SysWOW64″下面;
程序不用更改, 路徑參數依然填寫”C:\Windows\System32\xxx.dll”;
問題解決!
原因:
簡單來說可以從SysWOW64的全稱找到原因:
32bit Windows On 64bit Windows(在64位Windows上的32位Windows)
詳情可參考以下鏈接:
什麼是SysWow64
LoadLibraryW() failing to load DLL in System32