首先,为什么我们要使用泛型呢?泛型其实有两个比较好的优点:1当取得一个值的时候不需要进行强制类型转换,比如一个ArrayList<String>取出的值不需要进行(String)object强制转换;2.使用泛型后,编译器会进行泛型类型检查,比如一个ArrayList<String>当你向里面添加一个Integer类型的值的时候,它将会报错,告诉你需要一个String类型的变量。
泛型类示例:
public class Pair<T> { private T firstName; private T lastName; public Pair(){ firstName = null; lastName = null; } public Pair(T firstName,T lastName){ this.firstName = firstName; this.lastName = lastName; } public T getFirstName() { return firstName; } public T getLastName() { return lastName; } public void setFirstName(T firstName) { this.firstName = firstName; } public void setLastName(T lastName) { this.lastName = lastName; } }泛型方法示例:
public static <T> T getMiddle(T[] a){ return a[a.length/2]; }虽然泛型用起来好处很多,但是也会有一些问题,比如当你的泛型方法是找出一个T[]里的最大值,因为我们知道两个对象之间可比较的话,需要实现Comparable接口里的compareTo方法,显然,如果我们想让T[里的内容可以比较,需要将T实现Comparable接口,例如原来的方法是public static<T> T getMax(T[] a)变为public static<T extends Comparable> T getMax(T[] a)。一个类型变量可以有多个限定,例如T extends Comparble&Serializable.
即使在程序中可以包含不同类型的Pair,比如Pair<String>,Pair<Integer>,但是经过类型擦除后,其实都会变成原始类型Pair,注意不能用类型变量替换基本类型,因此没有Pair<double>只有Pair<Double>,原因是类型擦除后,Pair具有Object的域,而Object不能存储double值。Pair<T>调用getClass()返回的都是Pair.class。泛型类是不能扩展Throwable类的,而且catch里是不能有类型变量的。
通配符类型:Pair<? extends Employee>表示任何泛型Pair类型,它的类型参数是Employee的子类,如Pair<Manager>;Pair<? super Manager>表示参数类型都是Manager的超类。
注:参考与java核心技术