令我们惊讶的是,以下语句 并没有 抛出异常!

Assembly.Load("System.Data, Version=4.0.99.99, Culture=neutral, PublicKeyToken=b77a5c561934e089");

GAC 仅包含 4.0.0.0 版本 - 没有 4.0.99.99 。请注意,尝试加载 4.1.0.0 失败。我们仅观察到 .NET 框架程序集的这种行为。

为什么会这样? .NET 框架程序集是否有任何默认程序集绑定(bind)重定向?是否有其他魔法在发生?

据我所知,只有在找到完全相同的版本时才应加载强命名程序集。

最佳答案

正如 Hans Passant 在评论中提到的,CLR 包含框架程序集的重定向机制,它将对旧框架库的引用重定向到新框架库。您可以通过查看 Fusion Log(使用 fuslogvw.exe 并将其配置为将所有绑定(bind)记录到磁盘)来了解该机制在工作,其中包含信息“在框架配置中找到的版本重定向”:

LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\Users\fabian.schmied\Desktop\Temp\ConsoleApplication3\ConsoleApplication3\bin\Debug\ConsoleApplication3.exe.Config
LOG: Using host configuration file:
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Version redirect found in framework config: 2.0.0.0 redirected to 4.0.0.0.
LOG: Post-policy reference: System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
LOG: Found assembly by looking in the GAC.

在您的示例中,Fusion 日志包含等效的行:
LOG: Version redirect found in framework config: 4.0.99.99 redirected to 4.0.0.0.

由此,我得出结论,同样的机制在这里发挥作用。似乎所有对 System.Data 高达 4.0.65534.65534 的引用都被重定向到 4.0.0.0。

(对于从 4.1.0.0 开始的版本,重定向不再起作用。)

关于c# - 为什么加载 System.Data 4.0.99.99 会成功?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/29037336/

10-15 15:01