在使用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调试非常有用。