C#中类型分析中的常见问题 Type

写代码的时候经常需要分析已有类型的信息

例如:分析现有类型自动生成类, 或者为现有的类自动增加一些功能

总结了一点点经验

以ClassA  a; 为例

1. 通过typeof(ClassA) 或者 a.GetType() 获取类型信息, 推荐使用typef() 可以避免空引用,而且有的时候不需要构造一个ClassA的实例,

  typeof(ClassA)的性能一点都不差,不要把它和反射混为一谈,

2.对于Type.IsPrimitive来说  很多常见的类型不是原生类型

  例如 String DateTime decimal 都不是原生类型

  按照MSDN的说明  原生类型只包括:http://msdn.microsoft.com/en-us/magazine/bb984984.aspx

3.对于数组来说 , typeof(ClassA [])

  可以使用Type.IsArray来判断是否数组

  可以使用Type.GetElementType 获取元素的类型 , 在这里等价于typeof(ClassA)

  数组实际上继承于System.Array, 但是数组也实现IEnumerable<T>的接口 (这会让数组和List<T>等常见类型可以按照同样的方式处理)

3.泛型来说 ,Typeof(List<ClassA>)

  可以使用Type.IsGenericType 来判断是否是泛型类型

  可以使用Type.GetGenericTypeDefinition()来获取泛型类型(开放类型) ,在这里等价于 typeof(List<>)

  使用Type.GetGenericArguments()获取泛型参数集合 在这里,集合中的第一个元素等价于typeof(ClassA)

  对于Dictionary<string,ClassA> 这样的字典定义来说, Type.GetGenericArugment()会返回两个类型,分别是typeof(string)和typeof(ClassA)  他的开放类型是typeof(Dictionary<,>)

4.可以调用Type.GetInterfaces() 然后判断某个类型是否继承与某个接口

  例如数组和List<T>都继承与IEnumerable<T> 这样就可以用统一的方式处理

5.可空值类型 例如 int? 本质上也是泛型 他的开放类型是typeof(System.Nullable<>)

这里的开放类型指的是类型不完全, 需要增加参数(一般是泛型参数) 才能构成一个真正的类型, 例如List<> , 增加泛型参数string 变为List<string>

开放类型还不是一个完整的类型 不能直接构造出一个实例

封闭类型已经是一个完整的类型了 可以new ..

转载于:https://www.cnblogs.com/PurpleTide/archive/2011/02/17/1957210.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值