Windows程序直接或间接通过LoadLibrary/LoadLibraryEx加载一个DLL时,Windows会按照一定的顺序去系统中搜索指定的DLL,这个顺序称之为DLL搜索顺序。
下面举例A.exe调用B.dll的情况:
一、系统环境影响
1.如果在LoadLibrary/LoadLibraryEx调用时B.dll被指定了路径而该路径下并不存在B.dll,LoadLibrary/LoadLibraryEx会直接失败。
2.如果B.dll这个模块已经存在于内存中,系统只作manifest检查和redirection检查,而不管指定的B.dll路径是否与内存中的B.dll一致,并且系统不会再试图搜索B.dll。
3.KnownDlls,注册表中的HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\KnownDLLs 登记了所谓KnownDlls的名称和它们的路径。如果B.dll存在于该键下,系统会加载该注册表项指定路径的B.dll,而不管它在LoadLibrary/LoadLiraryEx被指定的路径。
4.如果被加载的B.dll依赖于其他的DLL,这些被依赖的DLL会按照B.dll没有指定路径时的相同方式加载。(假如B.dll依赖于它相同目录下的DepDll.dll,搜索DepDll.dll时并不会从B.dll所在目录开始)
二、标准的DLL搜索顺序
不附加任何其他条件时,标准的DLL搜索顺序如下:
1.应用程序的加载目录:D:\SR0ad
2.当前目录(默认为程序加载目录