一. 泛型的擦除:泛型是工作在编译阶段的,一旦程序编译成class文件,class文件中就不存在泛型了,这就是泛型擦除。
在我们写代码的时候,会写上泛型,但是在编译的过程中,会将我们所写的泛型删除掉,这就是泛型的擦除,例如:
public class Test {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("A");
list.add("B");
list.add("C");
String rs = list.get(2);
System.out.println(rs);
}
}
上面的代码中,我们对list对象使用了泛型,规定只能添加/获取String类型。
编译后,我们来反编译一下我们的代码,看看编译后是什么样子,得到:
可以看出,我们所写的泛型被擦除了,底层被恢复成了object,然后使用强制类型转换。
二. 泛型不支持基本数据类型,只能支持对象类型(引用数据类型)
当我们想规定泛型为一些基本数据类型的时候,是不能直接使用int,double等的:
ArrayList<int> list1 = new ArrayList<int>();
ArrayList<double> list2 = new ArrayList<double>();
如果我们一定要规定只能输入这种基本数据类型,应该这么写:
ArrayList<Integer> list1 = new ArrayList<int>();
ArrayList<Double> list2 = new ArrayList<double>();
上面的Integer就是int的对象数据类型,Double就是double的对象数据类型。在这种情况下使用list.add所添加的内容将会被当作对象来处理。