通过ArrayList集合来进行测试:
import java.util.ArrayList;
public class FanXingTest {
public static void main(String[] args) {
ArrayList list1 = new ArrayList();
ArrayList<String> list2 = new ArrayList<String>();
list2.add("hello");
// list2.add(20); //编译时期由于泛型的作用,这条语句会报错
// 运行时刻动态加载类
Class c1 = list1.getClass();
Class c2 = list2.getClass();
System.out.println(c1 == c2); // true
}
}
反射操作都是编译之后的操作(变成字节码之后),是运行时期的操作。
从上面的结果可以看出编译之后集合的泛型是去泛型化的
下面通过反射来验证:泛型绕过编译无效
import java.lang.reflect.Method;
import java.util.ArrayList;
public class FanXingTest {
public static void main(String[] args) throws Exception {
ArrayList list1 = new ArrayList();
ArrayList<String> list2 = new ArrayList<String>();
list2.add("hello");
// 运行时刻动态加载类
Class c1 = list1.getClass();
Class c2 = list2.getClass();
Method m = c2.getMethod("add", Object.class); // 方法名以及参数类型(写为Object类型,这样所有类型都可以添加)
// 通过invoke方法调用目标类的方法 将20添加进list2中
m.invoke(list2, 20);
System.out.println(list2.size()); // 2
System.out.println(list2); // [hello, 20]
}
}
经过上面的测试,说明Java中集合的泛型是防止错误输入的,只在编译阶段有效,在运行时期就会失效。