如果我没有错,如果应用程序在其清单中指定了依赖项,Windows将从C:\Windows\WinSxS\xxx\文件夹加载指定版本的DLL。
当我研究C:\Windows\System32\dccw.exe --这是windows上的“显示颜色校准”应用程序时,我看到了这种奇怪的行为:
Application manifest has only one dependency - "Microsoft.Windows.Common-Controls"
which is basically the - comctl32.dll

但是,当您运行dccw.exe时,它会从WinSXS文件夹加载两个DLL;comctl32.dll和GdiPlus.dll。

清单中不应该存在GdiPlus.dll的依赖项。还是我不明白WinSxS是如何正确工作的?
发布于 2022-05-03 18:31:26
不需要在应用程序清单中指定所有依赖项。你可以添加一些,但忽略另一些。
正如汉斯在评论中提到的,WinSxS下的WinSxS是指向system32中相同文件的硬链接。
> C:\Windows\system32>fsutil.exe hardlink list GdiPlus.dll
\Windows\WinSxS\amd64_microsoft.windows.gdiplus.systemcopy_31bf3856ad364e35_10.0.
19041.1645_none_5b73408eab60fd9c\GdiPlus.dll
\Windows\System32\GdiPlus.dll因此,从功能上讲,加载该文件的“副本”并不重要。
至于为什么进程似乎要从WinSxS加载..。两个硬链接是难以分辨。没有任何记录建议默认将WinSxS用作DLL搜索位置。
这可能就是Process选择如何报告文件的位置(?)。如果您与其他工具(如(古旧的)依赖沃克或依赖关系 )相比,则会得到不同的结果。一个显示WinSxS的位置,另一个显示system32


https://stackoverflow.com/questions/72095533
复制相似问题