1. 程式人生 > >C#中型別分析中的常見問題 Type - 轉

C#中型別分析中的常見問題 Type - 轉

http://www.cnblogs.com/yuanyuan/archive/2012/08/16/2642281.html

 

寫程式碼的時候經常需要分析已有型別的資訊
例如:分析現有型別自動生成類, 或者為現有的類自動增加一些功能
總結了一點點經驗
以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 ..

http://www.cnblogs.com/yuanyuan/archive/2012/08/16/2642281.html

 

寫程式碼的時候經常需要分析已有型別的資訊
例如:分析現有型別自動生成類, 或者為現有的類自動增加一些功能
總結了一點點經驗
以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 ..