泛型擦除:泛型是jdk1.5之后引入的概念,但是为什么可以和之前的版本兼容呢?就是因为采用了泛型擦除的机制,泛型信息只保留在编译阶段,在进入JVM之前,会发生泛型擦除
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<>();
list.add(1);
try {
Method add = list.getClass().getMethod("add", Object.class);
add.invoke(list,"xiao");
} catch (Exception e) {
e.printStackTrace();
}
System.out.println(list);
}
可以看上面的这段代码,我指定的泛型是Integer,但是因为泛型只存在与编译期,所以我们可以在运行时利用反射来做到向其中添加元素的目的
上面代码的运行结果,我们可以发现我们成功的添加了String类型。这是因为在运行期泛型都已经被擦除了,add方法可以添加的元素范围变成了Object,但是如果指定了上限,比如 泛型的上限时String,那么运行时就会将String转译为类型上限,测试如下
class Test1<T>{
T obj;
public Test1(T obj){
this.obj = obj;
}
}
Test1时一个泛型类,我们来看它在运行时的字段时什么类型
```java
Test1<String> test1 = new Test1<>("xiao");
Field[] fields = test1.getClass().getDeclaredFields();
for (Field field : fields) {
System.out.println(field.getName() +"----"+ field.getType().getName());
}
结果如下
![在这里插入图片描述](https://img-blog.csdnimg.cn/91a36ec582ce49999361f8ed3203f979.png)
显然,是转译为了Object,有上限时的情况也是一样的,只是转译为了上限类型而已
是自己的一些理解,希望大家指正