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,你應該這樣

  1. 用GetCurrentDir保存當前的工作目錄
  2. 用SetCurrentDir將當前的工作目錄,設置為你的DLL所在的路徑,需要使用絕對路徑
  3. 用LoadLibrary你的DLL
  4. 使用SetCurrentDir恢復到原來的工作路徑

如下所示

TCHAR chCurDir[MAX_PATH] = {0}; 
GetCurrentDirectory(MAX_PATH, chCurDir); 
SetCurrentDirectory(_T("E:\\test\\")); 
m_hDLL = LoadLibrary(_T("MyTest.dll")); 
SetCurrentDirectory(chCurDir); 

dll的加載順序

  1. EXE所在目錄;
  2. 當前目錄GetCurrentDirectory();
  3. 系統目錄GetSystemDirectory();
  4. WINDOWS目錄GetWindowsDirectory();
  5. 環境變量 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

推薦閱讀: