8

我正在尝试基于Environment.Is64BitProcess.
这基本上是这样工作的:

  • 为事件注册一个事件处理程序AppDomain.AssemblyResolve
  • 在事件处理程序中,从依赖于 CPU 类型的子路径加载程序集:

    private Assembly OnAssemblyResolve(object sender, ResolveEventArgs args)
    {
        // args.Name is the display name of an assembly, e.g.:
        // MyAssembly, Version=5.0.0.0, Culture=neutral, PublicKeyToken=abcdefghijklmn
        if(!args.Name.Contains("MyAssembly"))
            return null;
    
        var path = Path.Combine(GetCpuTypeDependentPath(), "MyAssembly.dll");
        return Assembly.LoadFrom(path);
    }
    

现在,这有一个问题,它不检查已加载程序集的版本、publicKeyToken 等。
我现在想做的是调用Assembly.Load并简单地提供额外的探测路径。我知道这不起作用,因为没有这样的过载。还有其他方法可以实现我的目标吗?

4

2 回答 2

2

只需将您找到的程序集的属性与请求的程序集进行比较。例如,版本检查可能如下所示:

private static Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args) {
    var name = new AssemblyName(args.Name);
    string path = System.IO.Path.Combine(IntPtr.Size == 8 ? "x64" : "x86", name.Name + ".dll");
    path = System.IO.Path.Combine(System.IO.Path.GetDirectoryName(Assembly.GetEntryAssembly().Location), path);
    var asm = Assembly.LoadFrom(path);
    var found = new AssemblyName(asm.FullName);
    if (name.Version != found.Version) throw new System.IO.FileNotFoundException(name.FullName);
    return asm;
}
于 2012-08-07T19:08:15.413 回答
1

没有自己探测程序集,我看不出你能做到这一点。您只需要启动另一个 AppDomain 来搜索匹配的程序集,这样您就可以卸载在探测期间加载的程序集。很遗憾

于 2012-08-07T14:43:56.813 回答