令我们惊讶的是,以下语句 并没有 抛出异常!
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/