本文以實例形式講述了C#泛型的用法,有助於讀者深入理解C#泛型的原理,具體分析如下:
首先需要明白什么時候使用泛型:
當針對不同的數據類型,采用相似的邏輯算法,為了避免重復,可以考慮使用泛型。
一、針對類的泛型
針對不同類型的數組,寫一個針對數組的"冒泡排序"。
1.思路
● 針對類的泛型,泛型打在類旁。
● 由於在"冒泡排序"中需要對元素進行比較,所以泛型要約束成實現IComparable接口。
2.關於泛型約束
where T : IComparable 把T約束為實現IComparable接口
where T : class
where T : struct
where T : IComparable, new() 約束泛型必須有構造函數
3.關於冒泡算法
● 之所以for (int i = 0; i <= length -2; i++),這是邊界思維,比如有一個長度為5的數組,如果0號位元素最終調換到4號位,每次調一個位,需要經過4次才能到4號位,即for(int i = 0; i <= 5-2, i++),i依次為0, 1, 2, 4,期間經歷了4次。
● 至於for (int j = length - 1; j >= 1; j--)循環,即遍歷從最后一個元素開始到索引為1的元素,每次與前一個位置上的元素比較。
4.關於比較
int類型之所以能比較,是因為int類型也實現了IComparable接口。
byte類型也一樣實現了IComparable接口。
二、自定義一個類,使之也能實現冒泡算法
冒泡算法涉及到元素比較,所以自定義類必須實現IComparable接口。
三、針對方法的泛型
繼續上面的例子,自定義一個類,並定義泛型方法。
另外,使用泛型方法的時候,除了按以下:
還可以這樣寫:
可見,泛型方法可以根據數組實例隱式推斷泛型是否滿足條件。
四、泛型的其它優點
1.避免隱式裝箱和拆箱
以下包含隱式裝箱和拆箱:
2.能在編譯期間及時發現錯誤
不使用泛型,在編譯期不會報錯的一個例子:
1.在當前文件中給泛型取別名