如何通过C#.NET中的反射机制来创建C#.NET泛型类的实例,并调用其方法??
请举一个简单易懂的小例子来说明… 反射普通类和反射泛型类是不同的… public abstract class BusinessManager { /// <summary> /// 添加一个新实体 /// </summary> /// <param name="entity"></param> public virtual void Add<T>(T MappedInstance) where T : Entity { Type entitymanage = typeof(EntityManager<T>); object obj = Activator.CreateInstance(entitymanage); MethodInfo method = entitymanage.GetMethod("Add"); method.Invoke(obj, new object[] { MappedInstance }); } } 类似这样的,但是这是使用反射普通类的方法,在这里有错误,希望帮我改成可以反射泛型类的,将这个改一下。 EntityManager<T>是一个泛型类
最佳答案
泛型反射和普通反射的区别就是泛型参数的处理上。 先看一个简单的例子。 class Class1<T> { public void Test(T t) { Console.WriteLine(t); } } 要利用反射动态创建该类型实例,并调用 Test 方法,我们可以使用如下方法。 Type type = typeof(Class1<int>); object o = Activator.CreateInstance(type); type.InvokeMember("Test", BindingFlags.Default | BindingFlags.InvokeMethod, null, o, new object[] { 123 }); 但如果泛型参数是未定的,我们该如何处理呢?其实 Type 已经增加了类似的处理机制。 static void InvokeTest(Type t, params object[] args) { Type type = typeof(Class1<>); type = type.MakeGenericType(t); object o = Activator.CreateInstance(type); type.InvokeMember("Test", BindingFlags.Default | BindingFlags.InvokeMethod, null, o, args); } 另外一种情况就是泛型方法,我们继续。 class Class1 { public void Test<T>(T t) { Console.WriteLine(t); } } 方法类似,只不过这回使用的是 MethodInfo.MakeGenericMethod()。 static void InvokeTest(Type t, params object[] args) { Type type = typeof(Class1); object o = Activator.CreateInstance(type); MethodInfo method = type.GetMethod("Test", BindingFlags.Instance | BindingFlags.Public); method = method.MakeGenericMethod(t); method.Invoke(o, args); }