我知道有很多类似的答案,但它们都不适合我。我有一个名为MyLibrary的类库。它只有一种类型。我将创建一个我的类型的实例到另一个appdomain,为什么我不使用Activator。
public class Test
{
public Test()
{
Console.WriteLine("Ctor of Test type.");
}
public void Hello(string name)
{
Console.WriteLine($"Hello {name}! I'm an instance method.");
}
}
我创建了一个简单的控制台应用程序。这是Main方法的代码。
static void Main(string[] args)
{
string path = @"example of my path";
AppDomain domain = AppDomain.CreateDomain("mydomain");
Assembly mylibrary = Assembly.LoadFrom(path);
Type typeOfTest = mylibrary.GetType("MyLibrary.Test");
var instanceOfTest = domain.CreateInstanceFrom(path, typeOfTest.FullName);
MethodInfo hello = typeOfTest.GetMethod("Hello");
hello.Invoke(instanceOfTest, new object[] {"Bob"});
}
调用Hello方法的正确方法是什么?我可以从Test类型创建和调用静态方法,但我对非静态实例方法无能为力?
答案 0 :(得分:3)
阅读本文以获取更多信息:How to load DLL in separate domain and use its methods?
您应该使用代理类(在本例中为Loader)。我从上面的文章中更改了部分代码。现在,Call方法将使用您的自定义应用程序域。
public class Loader : MarshalByRefObject
{
object CallInternal(string dll, string typename, string method, object[] parameters)
{
Assembly a = Assembly.LoadFile(dll);
object o = a.CreateInstance(typename);
Type t = o.GetType();
MethodInfo m = t.GetMethod(method);
return m.Invoke(o, parameters);
}
public static object Call(AppDomain domain, string dll, string typename, string method, params object[] parameters)
{
Loader ld = (Loader)domain.CreateInstanceAndUnwrap(Assembly.GetExecutingAssembly().FullName, typeof(Loader).FullName);
object result = ld.CallInternal(dll, typename, method, parameters);
AppDomain.Unload(domain);
return result;
}
}