[CSharp]C#2.0 锐利体验系列课程 (1):泛型编程-学习笔记

问题:下面的定义中,哪个是错误的
1 class C<U,V>{}
2 class D:C<string,int>{}
3 class E<U,V>:C<U,V>{}
4 class F<U,V>:C<string,int>{}
5 class G:C<U,V>{}

解释
1 泛型定义
2 D是普通类,C是实例化的泛型类垿IMG src="http://www.cnblogs.com/blog/smile19.gif">
3 E是子泛型类型,C是基泛型类型,C使用了子的泛型参敿IMG src="http://www.cnblogs.com/blog/smile19.gif">
4 F是泛垿C已经实例匿IMG src="http://www.cnblogs.com/blog/smile19.gif">
5 G是类,C是泛型类垿IMG src="C:\Program Files\BlogJet\Data\Smiles\smile20.gif">

注释
可以在基类中包含泛型类型的声明。但是注意:基类如果是泛型类,它的类型参数要么已实例化,要么来源于子?/FONT>

————————

泛型类型的成?FONT>

class C<V>{
    public V f1;     // 声明f1
    public D<V> f2;  // 引用其它泛型类型来定义成员f2
    public C(V x){   // 方法
        this.f1 = x;
    }
}

————————-

泛型接口

定义方式入泛类型的定义一栿BR>interface IList<T>{
    T{} MethodA();
}
interface IDictionary<K,V>{
    void MethodB(K k , V v);
}

class List<T> : IList<T> , IDictionary<int,T>
{
    public T[] MethodA(){}
    public void MethodB(int i,T t){}
}

—————————-

泛型方法

public class Finder{
    public static int Find<T> ( T[] items , T item )
    {
        for(int i;i<items.Length;i++){
            if(items[i].Equals(item){return i;}
        }
    }

}

——————————

泛型方法的重?FONT>

class c{
    void F<T>(int x);
    void F(int x);
    public abstract T F<T,U>(T t,U u) where U:T;
}

重写
class cc : c{
    public override X F<X,Y>(X x,Y y){}
}

-----------------

基类约束

class A{public void F1(){...}}
class B{public void F2(){...}}

class C<S,T>
where S: A
where T: B
{
    // 可以在类型S上调用F1方法
    // 可以在类型B上调用F2方法
    ...
}

posted on 2005-09-16 22:08  徐中  阅读(1206)  评论(2编辑  收藏  举报

导航