假设有2个DLL, Class1和Class2. Class1引用Class2, 并调用Class2里的方法。
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->//Class1.Dll
namespacefeiyun0112.cnblogs.com
{
publicclassClass1
{
publicvoidDoSomething(){Class2.Hello();}
}
}
//Class2.Dll
namespacefeiyun0112.cnblogs.com
{
publicclassClass2
{
publicstaticvoidHello(){MessageBox.Show("HelloWorld!");}
}
}
如果我们动态调用Class1里的方法,会报无法加载"Class2"的异常
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->stringpath=@"C:\test\Class1.dll";
Assemblyassembly=Assembly.LoadFile(path);
Typetype=assembly.GetType("feiyun0112.cnblogs.com.Class1");
objectobj=Activator.CreateInstance(type);
MethodInfomethod=type.GetMethod("DoSomething",BindingFlags.Public|BindingFlags.Instance);
if(method!=null)
{
method.Invoke(obj,null);
}
解决的方法其实也很简单,在对程序集的解析失败时, 会触发AppDomain.AssemblyResolve事件, 我么只需要在事件中进行处理,
将需要的Dll加载到应用程序域,动态调用的程序集就可以正常使用了。
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->AppDomaincurrentDomain=AppDomain.CurrentDomain;
currentDomain.AssemblyResolve+=newResolveEventHandler(MyResolveEventHandler);
staticAssemblyMyResolveEventHandler(objectsender,ResolveEventArgsargs)
{
stringstrFielName=args.Name.Split(',')[0];
returnAssembly.LoadFile(string.Format(@"C:\test\{0}.dll",strFielName));
}
1482

被折叠的 条评论
为什么被折叠?



