NET 4.0有一个新的 GAC,为什么?

%windir%\Microsoft.NET\assembly\是新的 GAC。这是否意味着现在我们必须管理两个 GAC,一个用于。NET 2.0-3.5应用程序和其他。NET 4.0应用程序?

问题是,为什么?

127334 次浏览

是的,因为有两个不同的全局程序集缓存(GAC),您必须分别管理它们。

在。net Framework 4.0中,GAC经历了一些变化。GAC被分成两个,一个对应一个CLR。

用于。net Framework 2.0和。net Framework 3.5的CLR版本是CLR 2.0。在前两个框架版本中不需要拆分GAC。Net Framework 4.0中破坏旧应用程序的问题。

为了避免CLR 2.0和CLR 4.0之间的问题,现在每个运行时的GAC都被划分为私有的GAC。主要的变化是CLR v2.0应用程序现在不能在GAC中看到CLR v4.0程序集。

Source .

为什么?

这似乎是因为在。net 4.0中有CLR的变化,而在2.0到3.5中没有。从1.1到2.0 CLR也发生了同样的事情。似乎GAC有能力存储不同版本的程序集,只要它们来自同一个CLR。他们不想破坏旧的应用程序。

请参见MSDN关于4.0中GAC的变化中的以下信息。

例如,如果.NET 1.1和.NET 2.0都共享同一个GAC,那么.NET 1.1应用程序从这个共享GAC加载程序集,就可以获得.NET 2.0程序集,从而破坏。net 1.1应用程序

用于两个。net的CLR版本 Framework 2.0和。net Framework 3.5 是CLR 2.0。因此,在那里 前两次都不需要吗 框架发布来拆分GAC。 打破旧的问题(在这个 case, .NET 2.0)应用程序 在Net Framework 4.0中重新出现 这一点CLR 4.0发布。因此, 避免相互之间的干扰问题 CLR 2.0和CLR 4.0, GAC现在是 拆分为每个私人gac 运行时。< / p >

随着CLR在未来版本中的更新,您可以期待同样的事情。如果只是语言改变了,那么你可以使用相同的GAC。

这没有什么意义,最初的GAC已经能够存储不同版本的程序集。没有什么理由假设程序会不小心引用错误的程序集,所有。net 4程序集都将[AssemblyVersion]提升到4.0.0.0。新的进程内并排特性不应该改变这一点。

我猜:已经有太多的。net项目打破了“永远不要直接引用GAC中的任何东西”的规则。我在这个网站上见过几次。

要避免破坏这些项目,只有一个办法:转移GAC。在微软,竞争是神圣的。

我也想知道为什么2 GAC,并在.NET 4.0有2个全局组装缓存(GAC)评论部分中发现了以下Mark Miller的解释:

Mark Miller说… 6月28日,2010 12:13 PM

< p >谢谢 这个职位。“干扰问题”是 故意模糊。在 写作,问题仍然存在 调查过了,但很明显

例如,一些应用程序使用 Assemby。加载的LoadWithPartialName 程序集的最高版本。如果 最高版本是用 V4,然后是v2(3.0或3.5)应用程序 如果不加载,应用程序就会崩溃, 即使有一个版本 会有用的。最初,我们 将GAC划分为 原来的位置,但那导致了 Windows升级时出现了一些问题 场景。这两种方法都涉及到代码 已经出货了,所以我们搬家了 我们的(版本分区GAC到 另一个地方。< / p > 这对大多数人来说应该没有任何影响 应用程序,并且不添加任何 维护的负担。这两个位置 应该只访问或修改 使用本地GAC api,处理 按照预期进行分区。的 有表面的地方是 的路径 GAC,如GetCachePath,或 检查加载的mscorlib路径

值得注意的是,我们修改了GAC 我们发布v2时的位置 当我们介绍建筑作为 组装标识的一部分。那些 添加了GAC_MSIL, GAC_32和GAC_64, 尽管一切仍在 %列出% \组装。不幸的是,这

希望对以后的读者有所帮助。