为什么loading System.Data 4.0.99.99会成功?

Why does loading System.Data 4.0.99.99 succeed?

令我们惊讶的是,下面的语句不会抛出异常!

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 Framework 程序集的这种行为。

为什么会这样? .NET Framework 程序集是否有任何默认的程序集绑定重定向?还有其他魔法吗?

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

正如 Hans Passant 在评论中提到的那样,CLR 包含框架程序集的重定向机制,可将对旧框架库的引用重定向到较新的框架库。您可以通过查看 Fusion 日志(使用 fuslogvw.exe 并将其配置为记录所有绑定到磁盘)来了解该机制的工作情况,其中包含信息 "Version redirect found in framework config":

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 开始的版本,重定向不再起作用。)