问题:
很多时候希望通过反射动态的加载一个程序集,通过反射调用其方法,调用完之后希望能够及时释放加载的DLL 文件,以便释放资源和更新dll
解决:
目前对于 Assembly, CLR 没有提供卸载 Assembly 的方法。而 Assembly 是 驻留在 Appdomain 中,Appdomain 是可以动态卸载和创建的。
比如有一个动态生成的类库:
动态的调用
很多时候希望通过反射动态的加载一个程序集,通过反射调用其方法,调用完之后希望能够及时释放加载的DLL 文件,以便释放资源和更新dll
解决:
目前对于 Assembly, CLR 没有提供卸载 Assembly 的方法。而 Assembly 是 驻留在 Appdomain 中,Appdomain 是可以动态卸载和创建的。
比如有一个动态生成的类库:
public class HelloWorld : MarshalByRefObject
{
public HelloWorld()
{
}
public void Task1(string s)
{
Console.WriteLine("Task1 " + s);
}
}
{
public HelloWorld()
{
}
public void Task1(string s)
{
Console.WriteLine("Task1 " + s);
}
}
动态的调用
// File: Invoke.cs
using System;
using System.Reflection;
using System.Runtime.Remoting;
public class InvokeMethod
{
public static void Main( String[] argv )
{
AppDomainSetup info = new AppDomainSetup();
info.ApplicationBase = "file:///" + System.Environment.CurrentDirectory;
AppDomain dom = AppDomain.CreateDomain("RemoteDomain", null, info);
Assembly asm =Assembly.Load("HelloWorld2");
Object obj=asm.CreateInstance("HelloWorld");
MethodInfo minfo=asm.GetType("HelloWorld").GetMethod("Task1") ;
minfo.Invoke(obj,new string []{"Task 1"});
AppDomain.Unload(dom);
}
}
using System;
using System.Reflection;
using System.Runtime.Remoting;
public class InvokeMethod
{
public static void Main( String[] argv )
{
AppDomainSetup info = new AppDomainSetup();
info.ApplicationBase = "file:///" + System.Environment.CurrentDirectory;
AppDomain dom = AppDomain.CreateDomain("RemoteDomain", null, info);
Assembly asm =Assembly.Load("HelloWorld2");
Object obj=asm.CreateInstance("HelloWorld");
MethodInfo minfo=asm.GetType("HelloWorld").GetMethod("Task1") ;
minfo.Invoke(obj,new string []{"Task 1"});
AppDomain.Unload(dom);
}
}
限制:
动态加载的dll 必须和host 在同一目录
参考:
http://www.gotdotnet.com/team/clr/AppdomainFAQ.aspx#_Toc514058481