你可以在腾讯电脑管家的电脑诊断中找到软件问题,选择丢失VC++组件,点击立即修复。
或
在工具箱,打开电脑诊所,丢失.Dll 文件,进行一键修复
你好!
要成功的反射另一个程序集中的类型及其方法,你必须先加载此程序集。
请确定目标程序集的路径,然后使用 Assembly.LoadFrom方法进行加载,最后在载入的程序集上进行反射即可。
以你的解决方案为例,如果你没有更改过各项目的输出路径以及TagClassCustom项目的输出程序集名称,那么应该在PTtemplate.cs中这样写:
var asm = Assembly.LoadFrom(@"..\..\..\TagClassCustom\bin\Debug\TagClassCustom.dll")
var targetType = asm.GetType("TagClassCustom.Class1")
var targetMethod = targetType.GetMethod("MethodName")
如果不在指定程序集上反射而是直接使用Type.GetType方法,将在当前执行的主程序集上进行查找,也即是你的Factory项目。
关于Factory项目引用TagClassCustom项目后依然异常的情况,原因在于项目引用也是基于文件进行引用的,你引用的只是TagClassCustom项目的输出程序集TagClassCustom.dll,所以依然需要使用Assembly.LoadFrom加载程序集后在该程序集上进行反射。
最后还要指出一点,关于MethodInfo.Invoke方法的第一个参数。
当Method是静态的,第一个参数随便写什么都会被无视,通常我们写null;
当Method所在的类型是静态的,第一个参数必须使用null否则异常;
非以上两种情况,第一个参数需传入Method所在的类型的一个实例,一般都是使用Activator.CreateInstance方法创建。
在你的代码中,虽然传入一个字符串Namespace在此例中并不会出错,但是在调用反射的一个非静态类中的非静态方法时则必定异常,敬请注意。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)