Java中的泛型

一、泛型类和泛型方法

public class Pair<T>{...}

public static <T> T getMiddle(T[] a){...}

public static <M> M,<V> V myCompate(M am,V av){...}

public static <T extends Comparable & Serializable> T getMiddle(T[] a)
增加限定符,之间用&分隔;可以有多个接口,如果有类继承关系,只能有一个,并且必须放在首位

二、泛型代码和虚拟机

虚拟机中的对象全部是普通的类对象,没有泛型对象。泛型只是作编译检查?

泛型对象首先要进行类型擦除生成原始类型,原始类型的名字就是删去类型参数后的泛型类型名。

public class Pair{...}

public static Object  getMiddle(Object[] a){...}

public static Object   myCompate(Object  am,Object  av){...}

public static <Comparable > getMiddle(Comparable[] a) 

程序使用泛型的时候,会强制进行类型转换,转换为实例化类型,再进行处理。

例如double inst[];getMiddle(inst),会先将Object[]转换为Double[]。

三、约束与限定

1、不能用基本类型实例化类型参数

2、运行时类型查询只返回原始类型

instanceof、强制类型转换、getClass()...

3、不能抛出也不能捕获泛型类型的实例

4、参数化类型的数组不合法

Pair<String>[] table = new Pare<Sting>[10];//ERROR

5、不能实例化类型变量

6、泛型类的静态上下文中类型变量无效

四、泛型类型的继承规则 

1、Manger是Employee的子类,但是Pair<Employee>和Pair<Manager>没有啥子关系

Java中的泛型

2、ArrayList<Manager>是List<Manger>的子类

 Java中的泛型

五、通配符类型

1、Pair<? extends Employee>表示类型参数是Employee子类的Pair类型;Pair<Manger>是Pair<? extends Employee>的子类;可以使用返回值,但是不能为方法提供参数

Pair<? extends Employee> = new Pair<Manger> //OK

void setField(Pair<? extends Employee>) //参数不能是Pair<Manger>

Java中的泛型

2、Pair<? super Manger>表示类型参数是Manger超类的Pair类型;可以为方法提供参数,但是不能使用返回值

void setField(Pair<? super Manger>)//参数可以是Pair<Employ>

Pair<? super Manger> = Pair<Employ> //ERROR

参考文献

《java核心技术 卷1:基础知识》