泛型笔记
所謂泛型,即通過參數化類型來實現在同一份代碼上操作多種數據類型。(類型的 多態) 是一種編程范式,它利用“參數化類型”講類型抽象化,從而實現更為靈活的復用。 1,可重用行 2,類型安全(在編譯期間發現問題,而不是在運行的時候) 3,效率更高(避免裝箱,拆箱的操作) 類型參數的命名準則: 1 務必使用描述性名稱命名泛型類型參數 2 考慮使用T作為具有單個字母類型參數的類型參數名 3 務必將“T”作為前綴 CLASS C{} CLASS D:C{} CLASS E:C{} CLASS F:C{} CLASS G:C{} //非法 因為非泛型類型繼承了未被實例化得泛型類 c#除可單獨聲明泛型類型(包括類和結構)外,也可在基類中包含泛型類型得聲明 。但基類如果是泛型類,它的類型參數要么已實例化,要么來源于子類(同樣是泛 型類型)聲明的類型參數。 泛型類型的成員 Class C{ PUBLIC V f1; PUBLIC D f2; PUBLIC C(V x){ This.f1=x; } } 泛型類型的成員可以使用泛型類型聲明中的類型參數。但類型參數如果沒有任何約 束,則只能在該類型上使用從SYSTEM.OJBECT繼承的共有成員。 泛型接口 interface ILIST{ T[] GetElements(): } interface IDictionary{ void Add(K key,V value) } class List:IList,IDictionary{ public T[] GetElements(){return null;} public void Add(int index,T value){} } 泛型接口的類型參數要目已實例化,要么來源于實現類聲明的類型參數 泛型方法的聲明與調用 public calss Finder{ public static int Find(T[] items,T item){ for(int i=0;i(new int[]{1,2,3,4,5,6,8,9}, 6); 泛型方法的重載 class Myclass{ void F1(T[] a,int i); //不可以構成重載方法 void F1(U[] a,int i); void F2(int x); //可以構成重載方法 void F2(int x); void F3(T t) where T:A; //不可以構成重載方法 void F3(T t) where T:B; } 泛型方法的重寫 abstract class Base{ public abstract T F(T t,U u) where U:T; public abstract T G(T t) where T:IComparable; } class Derived:Base{ //合法的重寫,約束被默認繼承 public override X F(X x,Y y){} //非法的重寫,指定任何約束都是多余的 public override T G(T t) where T:Icomparable{} } 泛型約束 1。對“所有泛型類型或泛型方法的類型參數”的任何假定,都要基于“顯示的約束”, 以維護類型安全 2。“顯示約束”由WHERE字句表達,分為4種 基類約束 接口約束 構造器約束 值類型/引用類型約束
轉載于:https://www.cnblogs.com/bloodycool/archive/2006/09/05/495161.html
總結
- 上一篇: 刚刚注册,打声招呼先
- 下一篇: 给有钱人办教育