public class Pair<T>{
private T first;
private T second;
public Pair(){
first = null;
second = null;
}
public Pair(T first , T second){
this.first = first;
this.second = second;
}
public T getFirst(){
return first;
}
public T getSecond(){
return second;
}
public void setFirst(T newValue){
first = newValue;
}
public void setSecond(T newValue){
second = newValue;
}
}
Pair<T,U> //第二种类型
// pair<T> 的原始类型如下
public class Pair {
private Object first;
private Object second;
public Pair(Object first, Object second){
this.first = first;
this.second = second;
}
public Object getFirst{ return first;}
public Object getSecond(return second;)
public void setFirst(Object newValue) { first = newValue; }
public void setSecond(Object newValue) { second = newValue; }
}
// 对比之前我们写的泛型类我们就可以看出编译器利用Object对象擦除了泛型类型
下面我们再考虑下面这种如何擦除类型变量
// 类似这一种 虚拟机就利用 Comparable来擦除相应的对象类型
public class Interval <T extends Comparable & Serializable>
当程序调用泛型类型,如果擦除返回类型,编译器将插入强制类型转换 Pair<Employee> buddies = . . Employee buddy = buddies.getFirstO; 例如上面这个代码,编译器翻译回两条虚拟机指令
类型擦除也会出现在泛型方法程序员通常认为下列的泛型方法
public static <T extends Comparable> T min(T[] a)
// 越看越奇怪 其实前面的尖括号意思是类型变量 后面紧跟的T代表着我们传统的返回值
// 前面的代码被编译器类型擦除之后变成下列的代码
public static Comparable min (Comparable[] a)
Pair<double> 是不对的 Pair<Double>是对的
// 类型擦除后对象只有Object对应的域
ArrayList:ArrayList<Pair<string>>
// 写不下去了 等我搞透彻再来写