首页 > 解决方案 > 为什么我的计算机上有多个相同的 C++ .dll 副本?

问题描述

我注意到 Microsoft Visual C++ 运行时库在我的计算机上重复出现,例如:在以下位置:

C:\Windows\System32
C:\Windows\SysWOW64
C:\Program Files\Common Files\microsoft shared
C:\Program Files (x86)\Mozilla Firefox
C:\Windows\WinSxS\amd64_microsoft-windows-u..lcrt- apifwd-winblue_31bf3856ad364e35_6.3.9600.18036_none_b157f27efd203c73
C:\Windows\WinSxS\x86_microsoft-windows-u..lcrt-apifwd-winblue_31bf3856ad364e35_6.3.96003395644bc_fc5

在此处输入图像描述

为什么是这样?我认为特定的 .dll 只能在 Windows 上注册一次?不是这样吗?您真的可以从多个位置注册相同的 .dll 吗?

我卸载了旧版本的 Skype,它在自己的文件夹中包含 C++ .dll。但是这样做会导致大量其他程序崩溃(例如 Adob​​e Acrobat 等)。我通过从控制面板的程序和功能窗口修复C++ 2015 可再发行组件来修复它。但是在检查损坏的文件是否被重新创建和重新注册时,我发现了很多版本。我如何知道哪一个已在 Windows 中注册?

如果我想编写引用这些 .dll 的代码,它会使用哪一个?

标签: visual-c++dllredistributablevcredist

解决方案


我在这篇文章中找到了一些原因。

考虑这种情况:您安装程序“A”,它使用库版本 1。然后您安装程序“B”,它也使用库版本 1,所以它不需要安装它 - 它可以使用已经存在的副本由程序“A”提供。现在您卸载程序“A”。可能会发生三件事:

  • 它卸载了库,因为它安装了它,它应该自行清理,没有意识到另一个程序依赖于该库。程序“B”因此中断。
  • 它永远不会卸载该库,因为另一个程序可能正在使用它。结果,图书馆登记入住,但他们从未离开。
  • 我们设计了一些方法来跟踪有多少已安装的程序正在使用该库,并且仅在卸载最后一个程序时才将其删除。不幸的是,任何单个程序的故障——无论是编程错误还是未能正确安装或卸载——都会破坏这种技术。最好的情况是,您只剩下不再需要的库副本,最坏的情况是,卸载一个程序可能会导致一个或多个其他不相关的程序失败。

一团糟。事实上,它是如此的混乱,以至于现在大多数程序都懒得去尝试和分享。

把你的命运交到别人手中:

最终,应用程序供应商意识到,通过依赖这样的共享库,他们将自己的命运掌握在碰巧使用同一库的相同版本的所有其他应用程序手中。如果只有其中一个人犯了错误,并且库在不应该发生的情况下被意外删除或更新,那么所有其他人都处于危险之中。

因此,应用程序供应商现在通常会安装他们自己管理且可以依赖的库副本。磁盘空间很便宜——比他们尝试共享时发生的错误和挫折要便宜得多。

所以现在,在我的机器上,许多不同的应用程序都带有它们自己的 Microsoft Visual C++ 运行时副本。

由于掌握了 自己的命运,因此每个人都更加稳定。

但是,仍然不清楚如何使用相同的名称但从不同的位置注册 dll 文件。我不认为这是可能的,但也许是。


推荐阅读