1

我将程序集动态加载为:

 var assembly = Assembly.LoadFile("PathOFMyDll");

无论如何,该程序集Filter在类中具有静态方法DynamicClass。因此,一旦我拥有该程序集,我就会将该方法执行为:

 var filter = assembly.GetType("DyamicClass").GetMethod("Filter");

 // that method accepts a object as parameter
 filter.Invoke(null, new object[] { "test" });

现在我的问题是:

我有委托delegate bool FilterDelegate(object item);为什么不可能使该类型的委托指向该方法以便拥有:

 FilterDelegate myPointerToMethodFilter = (FilterDelegate)assembly.GetType("DyamicClass").GetMethod("Filter");
 bool result = myPointerToMethodFilter("test");

请注意,编译器仅在尝试编译时才会抱怨。我没有收到任何语法错误。

4

1 回答 1

2

可以从MethodInfo对象创建委托,但强制转换是不够的。

相反,使用Delegate.CreateDelegate()

MethodInfo myMethodFilter = assembly.GetType("DyamicClass").GetMethod("Filter");
FilterDelegate myPointerToMethodFilter = (FilterDelegate)Delegate.CreateDelegate(typeof (FilterDelegate), myMethodFilter);
于 2012-09-11T16:01:48.127 回答