C#中的泛型和反射经常是一起工作的,因此这里就一次性的加以介绍了。
由于c#是强类型语言,一般来说函数的返回类型和参数的类型都是一早写好的,这也就造成了很多时候不像js那样方便使用,不够灵话。
因此就有了这个泛型,它可以让你的函数和参数在调用的时候才决定类型。如下例所示:
public T abc<T>(T word) { return word; return default(T); //关键字default可以对引用类型返回nullAble,int类型返回0,初始化一个T的感觉啦 } abc<string>("x"); //struct 是 值类型 //好处调用的是如果参数是值类型可以不用著名 test(100) 而不需要 test<int>(100); public void test<T>(T number) where T : struct { int z = Convert.ToInt32(number); //调用 test(100); } //下面的不知道好处在哪用在什么地方, public void test2<T>(T lei) where T : class { } public void test3<T>() where T : stooges { } public T test4<T>() where T : new() { T abc = new T(); return abc; } public class stooges { }
加了where 我就不清楚在什么地方用的上了,这个以后再研究
反射能让我们的代码运行时动态的获取一些对象或者类的属性值等等,甚至是调用它们。
先来一个常用到的,我们想获取一个对象的全部属性和值, 用js 是:
for(var attr in object) { object[attr]=value, attr = attr } var obj = new abc(); Type T = typeof(abc); //typeof(Class) 而不是 typeof(object) 哦 Type V = obj.GetType(); //obj.GetType() 就是typeof(object的class) PropertyInfo[] attrs = obj.GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public); //获取attrs foreach (PropertyInfo attr in attrs) { string key = attr.Name; //获取attr name object value = attr.GetValue(obj, null); //获取value Type type = attr.PropertyType; //类型 }
关键就是那个 Type , 获取Type后就可以做很多了
C#常用的方法为:
T.GetProperty("key").GetValue(obj, null); //read a key value T.GetProperty("key").SetValue(obj, "", null); //write a value to key //注意如果是字典 T.GetProperty("Item").GetValue(obj, new [] {"id"}); //先拿Item 然后才通过 new[] {这里放指定的key}
再来看看更详细的
class MyClass { public int x { get; set; } public int y { get; set; } public MyClass(int i) { x = y + i; } public MyClass(int i, int j) { x = i; y = j; } public int sum() { return x + y; } }
我们想获取这个Class 的构造函数 :
Type t = typeof(MyClass); ConstructorInfo[] constructors = t.GetConstructors(); //使用这个方法获取构造函数列表 for (int i = 0; i < constructors.Length; i++) { ConstructorInfo constructor = constructors[i]; //构造函数也是方法所以有 GetParameters ParameterInfo[] parameters = constructor.GetParameters(); //获取当前构造函数的参数列表 string paraTypeName = parameters[0].ParameterType.Name; //方法的参数类型名称 string paraName = parameters[0].Name;// 方法的参数名 } //调用构造函数 object[] args = new object[2]; args[0] = 10; args[1] = 20; //不用new 直接实例化 object instance = constructors[0].Invoke(args); //实例化一个这个构造函数有两个参数的类型对象,如果参数为空,则为null object instance = (t)Activator.CreateInstance(t); 还有这种实例的方法,不清楚可以放参数没有
调用方法如下:
MethodInfo[] methods = T.GetMethods(BindingFlags.Public | BindingFlags.DeclaredOnly | BindingFlags.Instance); foreach (MethodInfo method in methods) { string return_name = method.ReturnType.Name; //返回方法的返回类型 string name = method.Name; if (name.Equals("sum", StringComparison.Ordinal)) //指定方法名调用 { int value = (int)method.Invoke(instance, null); //instance是之前实例好的对象,方法就是在这个对象之中 } }
下面是一些参考代码:
Type t = typeof(MyClass); Console.WriteLine("----------------Method------------------"); MethodInfo[] methods = t.GetMethods(); foreach (MethodInfo method in methods) { Console.WriteLine("Method:" + method); //Console.WriteLine(method); //Console.WriteLine("返回值:" + method.ReturnParameter); } Console.WriteLine("---------------Field-------------------"); //字段 ,比如这种 private static string name; FieldInfo[] fields = t.GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Static); foreach (FieldInfo field in fields) { Console.WriteLine("Field:" + field); } Console.WriteLine("--------------Member--------------------"); //成员即方法和属性 MemberInfo[] members = t.GetMembers(); foreach (MemberInfo member in members) { Console.WriteLine("Member:" + member); } Console.WriteLine("--------------Property--------------------"); //属性 PropertyInfo[] properties = t.GetProperties(); foreach (PropertyInfo property in properties) { Console.WriteLine("Property:" + property); } Console.WriteLine("--------------Constructor--------------------"); //构造函数 ConstructorInfo[] constructors = t.GetConstructors(BindingFlags.NonPublic | BindingFlags.Instance); foreach (ConstructorInfo constructor in constructors) { Console.WriteLine("Constructor:" + constructor); }
调用不用记太清楚,关键知道什么东西可以用反射获取和调用就可以了。
比较常使用的地方是用泛型写方法的时候,比如我们的泛型是一个不确定的类,然后我们要获取attr值等等的,就很好可以使用反射了。
还有通过string来调用方法,这个在js很长用到,比如 obj["methodName"](); 这里也可以用到反射来实现。
此外还需要注意: 反射的性能是很慢的,也可以说动态就是慢,这个是很正常的,反射的性能优化可以参考使用动态编程之类的,不过这里就不提了。
本文向大家介绍C#反射应用实例,包括了C#反射应用实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#反射应用。分享给大家供大家参考。具体如下: 通过反射实现多系统数据库的配置 通过定义接口,反射实例化配置的节点的值 配置App.config: 通过System.Configuration.ConfigurationManager.AppSettings读取该key的value,使用C
本文向大家介绍Java 中利用泛型和反射机制抽象DAO的实例,包括了Java 中利用泛型和反射机制抽象DAO的实例的使用技巧和注意事项,需要的朋友参考一下 Java 中利用泛型和反射机制抽象DAO的实例 一般的DAO都有CRUD操作,在每个实体DAO接口中重复定义这些方法,不如提供一个通用的DAO接口,具体的实体DAO可以扩展这个通用DAO以提供特殊的操作,从而将DAO抽象到另一层次,令代码质量有
本文向大家介绍Java 泛型实例详解,包括了Java 泛型实例详解的使用技巧和注意事项,需要的朋友参考一下 理解Java泛型最简单的方法是把它看成一种便捷语法,能节省你某些Java类型转换(casting)上的操作: 上面的代码自身已表达的很清楚:box是一个装有Apple对象的List。get方法返回一个Apple对象实例,这个过程不需要进行类型转换。没有泛型,上面的代码需要写成这样: 很明显,
本文向大家介绍C#通过反射创建自定义泛型,包括了C#通过反射创建自定义泛型的使用技巧和注意事项,需要的朋友参考一下 本文以实例形式讲述了C#通过反射创建自定义泛型的实现方法,分享给大家供大家参考。具体如下: 比如有这样一个泛型:Demo.GenericsSimple<T,TT> 我想要通过反射创建一个Demo.GenericsSimple<string,int>的实例可以通过下面的格式进行创建:
问题内容: 是否可以在Java中以反射方式实例化泛型?使用此处描述的技术,由于类标记不能通用,我会遇到错误。请看下面的例子。我想实例化一些实现Creator的Creator子类。实际的类名作为命令行参数传递。这个想法是为了能够在运行时指定Creator的实现。还有另一种方法可以完成我在这里要做的事情吗? 编辑:我喜欢Marcus的方法,因为它是最简单,最实用的方法,不会绕开整个泛型的东西。我可以在
本文向大家介绍C#根据反射和特性实现ORM映射实例分析,包括了C#根据反射和特性实现ORM映射实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#根据反射和特性实现ORM 映射的方法。分享给大家供大家参考。具体如下: (一)关于反射 什么是反射? 反射就是在运行时,动态获取对象信息的方法。比如:运行时获得对象有哪些属性,方法,委托等。 反射的作用? 能够实现运行时,动态调用对象的方