gpt4 book ai didi

windows - 如何将第三方 Windows DLL 组织到我的应用程序文件夹中的子文件夹中?

转载 作者:可可西里 更新时间:2023-11-01 13:29:59 25 4
gpt4 key购买 nike

我们有一个应用程序依赖于多组第三方 DLL。不幸的是,这些第三方 DLL 的编写者都没有非常一致地命名它们,因此很难看出哪个 DLL 属于哪个组。

为了尝试和管理它,我们希望将第三方 DLL 组放在我们应用程序文件夹中的一个文件夹中,而不是像这样与应用程序一起放置。

--> Application Folder
--> Application.exe
--> MyDLL1.dll
--> MyDLL2.dll
--> Third Party 1 DLL folder
--> Third Party 1 DLL 1.dll
--> Third Party 1 DLL 2.dll
--> Third Party 1 DLL 3.dll
--> Third Party 2 DLL folder
--> Third Party 2 DLL 1.dll
--> Third Party 2 DLL 2.dll
--> Third Party 2 DLL 3.dll

我的问题是如何让动态链接器找到并加载它们?

我们可以使用 LoadLibrary() 和 GetProcAddress() 手动完成此操作,但是这非常乏味。看起来我们可以通过 list 和“探测”来做到这一点,但这似乎仅限于 Windows 7(我们需要在 XP 及更高版本上工作)。

更新

我们最终使用 list 来做到这一点(感谢@Chris)——我们还必须跳过其他几个环节,以防有人在寻找解决方案!

首先,我们的“程序集”实际上有几个 DLL,我们链接到一个 DLL,然后再链接到其他 DLL。所有这些 DLL 都需要将程序集依赖项添加到它们的 list 中(您可以使用 mt.exe 来执行此操作,而无需访问这些 DLL 的源代码)。

其次,程序集需要与 DLL 一起使用,而不是与 EXE 一起使用 - 我们的 DLL 实际上是一个已经在应用程序子文件夹中的插件。

这是我们的最终布局:

--> Application Folder
--> Application.exe
--> Plugins folder
--> MyDLL1.dll
--> Third Party 1
--> Third Party 1.manifest
--> A.dll
--> B.dll
--> C.dll

如果 MyDLL1.dll 是链接到 A.dll 的插件,并且 A.dll 链接到 B.dll 和 C.dll,则:

  1. “Third Party 1.manifest”需要将所有的A.dll、B.dll和C.dll作为一个程序集包含在内
  2. “MyDLL1.dll”在其 list 中需要一个依赖条目到“第三方 1”,否则动态链接器将找不到 A.dll
  3. A.dll 需要在其 list 中有一个到“第三方 1”的依赖条目,否则动态链接器将找不到 B.dll 和 C.dll
  4. “第三方 1”文件夹需要放在“MyDLL1.dll”旁边,而不是放在“Application.exe”旁边

对我来说,(3) 有点烦人。您会认为链接器会在程序集中查找相关的 DLL。

最佳答案

您可以在不进行探测的情况下使用 list 来完成此操作。创建“假”程序集 - 通过定义包含 dll 的 .manifests。 (不需要为此在 dll 中进行任何更改)由于程序集支持已添加到 NT 5.1 (Windows XP),Windows 加载程序首先通过扫描具有程序集名称的文件夹来查找程序集。

因此,例如,如果您需要为 Visual C 2008 与您的应用程序一起分发 Microsoft Visual C 运行时,您可以创建如下所示的文件夹结构:

--> Application Folder
--> Application.exe
--> MyDll1.dll
--> MyDll2.dll
--> Microsoft.VC90.CRT
--> Microsoft.VC90.CRT.manifest
--> msvcr90.dll
--> msvcp90.dll
--> msvcm90.dll

同样的方案也适用于您的第 3 方 dll。然后你需要做的就是将“假”程序集作为依赖程序集添加到你的应用程序的 list 中(如果你的 dll 有 list ,(并且他们访问第 3 方 dll)那么他们的 list 也必须有条目。

描述程序集的 list 文件需要一个 assemblyIdentity 和每个 dll 一个文件节点:

<assembly manifestVersion="1.0">
<assemblyIdentity type="Win32" name="Assembly Name" version="1.0.0.0" processorArchitecture="x86" />
<file name="dll1.dll" />
<file name="dll2.dll" />
</assembly>

并且您的应用程序和 dll 是使用 MS Visual Studio 2005 或更高版本构建的,以下 pragma 指令将使您的应用程序在程序集中查找 dll:

 #pragma comment(linker, "/manifestDependency:\"name='Assembly Name' processorArchitecture='*' version='1.0.0.0' type='win32' \"")

关于windows - 如何将第三方 Windows DLL 组织到我的应用程序文件夹中的子文件夹中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4051154/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com