我试着这样做:
Type ThreadContextType = typeof(Application).GetNestedType("ThreadContext", System.Reflection.BindingFlags.NonPublic);
MethodInfo FDoIdleMi = ThreadContextType.GetMethod("FDoIdle", BindingFlags.NonPublic |
BindingFlags.Instance, null, new Type[] { typeof(Int32) }, null);ThreadContextType正常,可FDoIdleMi为null。我知道GetMethod调用有问题,因为FDoIdle来自UnsafeNativeMethods.IMsoComponent接口。
如何做到这一点?谢谢。
发布于 2008-10-18 16:32:54
您需要完全限定方法名,因为它们使用显式接口实现:
Type type = typeof( Application ).GetNestedType( "ThreadContext",
BindingFlags.NonPublic );
MethodInfo doIdle = type.GetMethod(
"System.Windows.Forms.UnsafeNativeMethods.IMsoComponent.FDoIdle",
BindingFlags.NonPublic | BindingFlags.Instance );根据记录,反思非公共成员通常是不好的做法,但您可能已经知道这一点。
编辑本着教人去钓鱼的精神,我通过在类型对象上调用GetMethods(...),并检查返回的数组来查看方法是如何命名的,从而解决了这一问题。果然,名称包含了完整的名称空间规范。
发布于 2008-10-18 16:35:34
虽然有点老生常谈,但这是可行的:
using System;
using System.Linq;
using System.Reflection;
using System.Windows.Forms;
public class Test
{
static void Main()
{
Type clazz = typeof(Application).GetNestedType("ThreadContext", BindingFlags.NonPublic);
Type iface = typeof(Form).Assembly.GetType("System.Windows.Forms.UnsafeNativeMethods+IMsoComponent");
InterfaceMapping map = clazz.GetInterfaceMap(iface);
MethodInfo method = map.TargetMethods.Where(m => m.Name.EndsWith(".FDoIdle")).Single();
Console.WriteLine(method.Name);
}
}有更多可靠的方法来匹配目标方法,但这一次恰好有效:)
https://stackoverflow.com/questions/215213
复制相似问题