1.為何引入泛型
當我們要對不同型別的引數執行類似的方法時:如下所示功能列印傳入引數的相關資訊,
class CommonMethdod { /// <summary> /// show int /// </summary> public static void ShowParam(int iParam) { Console.WriteLine($"this is {typeof(CommonMethdod)},type={iParam.GetType().Name},param={iParam}"); } public static void ShowParam(string sParam) { Console.WriteLine($"this is {typeof(CommonMethdod)},type={sParam.GetType().Name},param={sParam}"); }
}
只是引數的不同,函式體以及函式名稱都相同,很快我們想到了一種替代方案:將函式形參改為Object,
public static void ShowParam(object oParam)//函式宣告oParam為object,但是實參為其子類-->LSP, { Console.WriteLine($"this is {typeof(CommonMethdod)},type={oParam.GetType().Name},param={oParam}"); }
這似乎能解決我們的問題,一個方法可以適用于所有型別,之所以能解決的原因是:
Object是所有類的基類; 任何父類出現的地方(Object作為函式簽名的形參),都可以用子類代替[實際傳入實參](里氏替換原則LSP),
但是其會存在這樣的問題:
- 性能問題:會出現裝箱與拆箱 ,此處為 int->object(裝箱),object->int實際型別(拆箱);
- 型別安全問題:???(泛型約束),
對于裝箱拆箱的問題,這里就要了解C#裝箱與拆箱的內部操作和C#記憶體模型,請移步自此處:https://blog.csdn.net/qiaoquan3/article/details/51439726,
關于泛型約束的問題,明天再寫,,,,
那泛型到底怎么使用呢---->
2、泛型的使用:
如下所示為泛型方法的使用:
/// <summary> /// 泛型方法代替上一個Object方法 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="tParam"></param> public static void ShowParam<T>(T tParam) { Console.WriteLine($"this is {typeof(T)},type={tParam.GetType().Name},param={tParam}"); }
我們在客戶端呼叫,代碼如下:
class Program { static void Main(string[] args) { CommonMethdod.ShowParam(1); CommonMethdod.ShowParam("abc"); Console.WriteLine("***********************Object********************"); object obj = 3.1415926; CommonMethdod.ShowParam(obj); Console.WriteLine("***********************Generic********************"); string str = "efg"; int intVal = 0; CommonMethdod.ShowParam<string>(str); CommonMethdod.ShowParam<int>(intVal); Console.ReadKey(); //性能測驗 for (int i = 0; i < 10; i++) { PerformanceTest.Run(); } } }
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/214625.html
標籤:C#
