我有一个项目使用 Assembly.Load 或 Assembly.LoadFile 加载同一程序集的多个版本。然后我使用 Assembly.CreateInstance 从该特定程序集创建一个类型。
在我创建的类型引用另一个依赖程序集之前,这很有效。我需要一种方法来拦截此特定程序集的请求以加载另一个程序集并为其提供正确的版本(或者更好的是探测路径)以查找其依赖关系。
这是必需的,因为我使用 Assembly.CreateInstance 创建的程序集的 v1 和 v2 通常也需要其依赖程序集的不同版本,但默认情况下,v1 和 v2 都将探测相同的目录。
我已经看到了一般如何为 AppDomain 执行操作的示例,但我需要以处理来自特定根程序集的所有解析的方式执行此操作。假设我做类似的事情:
AppDomain.CurrentDomain.AssemblyResolve += delegate(object sender, ResolveEventArgs args)
{
//Use args.RequestingAssembly to determine if this is v1 or v2 based on path or whatever
//Load correct dependent assembly for args.RequestinAssembly
Console.WriteLine(args.Name);
return null;
};
这可能适用于我的目标程序集立即引用的依赖项,但是那些依赖项引用的程序集呢?如果 v1 引用了 Depv1,而 Depv1 本身又引用了 DepDepv1,我需要能够知道这一点,这样我才能确保它能够正确找到它们。
在那种情况下,我想我需要以某种方式跟踪它。也许通过添加自定义程序集证据 - 尽管我无法让它工作,而且似乎没有任何“程序集元数据”属性可以在运行时添加。
如果我可以简单地指示特定程序集从特定目录加载其所有依赖项,那将容易得多。
更新
我设法使用 AssemblyResolve 事件根据 RequestingAssembly 的路径加载依赖程序集,但这似乎是一种有缺陷的方法。似乎使用哪个依赖的程序集版本完全取决于哪个版本恰好首先加载。
例如:
- 加载 v1
- 加载 v2
- 参考 v1 导致 Depv1 的负载
- 参考 v2 导致 Depv2 的负载
- v1 中的代码使用来自 Depv1 (Works) 的类型
- v2 中的代码使用来自 Depv2 的类型 <-- 失败,因为它从 Depv1 获取类型!
此时我只是在推断步骤 5 和 6,但我确实看到 Depv1 AND Depv2 正在加载。