所以我需要在同一个解决方案中使用同一个 dll 的两个不同版本,我设法通过使用外部别名来做到这一点(任何尝试使用同一个 dll 的两个不同版本的人都应该尝试这个解决方案)。问题是,现在我的应用程序一开始运行,我就会得到这个 FileLoadException HRESULT: 0x80131040。有人知道此问题的可能原因和/或解决方案吗?
是的,我不得不更改其中一个 dll 的名称,不,此时仅使用后一个版本是不可能的。
我设法使用 appDomain 使用了两个不同版本的同一个 dll。它非常干净且始终有效,但是是的,它涉及反射和 appDomain 创建,这是性能关键型应用程序的开销。这是如何在控制台应用程序中完成的,您可以在 asp.net 中执行相同的操作:
//Console app
using System;
using System.IO;
using System.Reflection;
namespace ConsoleApp1
{
class Program
{
static System.AppDomain oldAssemblyDomain = null;
static System.AppDomain newAssemblyDomain = null;
static void Main(string[] args)
{
LoadOldVersion();
LoadNewVersion();
Console.ReadLine();
}
private static void LoadOldVersion()
{
oldAssemblyDomain = System.AppDomain.CreateDomain("oldAssemblyDomain", null);
oldAssemblyDomain.DoCallBack(()=>{
string dllName = "ClassLibrary1.dll";
Assembly assembly = Assembly.LoadFile(Directory.GetCurrentDirectory() + @"\" + dllName);
Type type = assembly.GetType("ClassLibrary1.Class1");
MethodInfo minfo = type.GetMethod("SayHello", BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Static | BindingFlags.Instance);
var returnValue=minfo.Invoke(Activator.CreateInstance(type), null);
Console.WriteLine(returnValue.ToString());
});
}
private static void LoadNewVersion()
{
newAssemblyDomain = System.AppDomain.CreateDomain("newAssemblyDomain", null);
newAssemblyDomain.DoCallBack(() =>
{
string dllName = "ClassLibrary2.dll";
Assembly assembly = Assembly.LoadFile(Directory.GetCurrentDirectory() + @"\" + dllName);
Type type = assembly.GetType("ClassLibrary1.Class1");
MethodInfo minfo = type.GetMethod("SayHello", BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Static | BindingFlags.Instance);
var returnValue = minfo.Invoke(Activator.CreateInstance(type), null);
Console.WriteLine(returnValue.ToString());
});
}
}
}
//Lib
namespace ClassLibrary1
{
public class Class1
{
public static string SayHello()
{
return "Hello 1";
}
}
}