1.泛型代码与JVM
1、创建泛型对象的时候,一定要指出类型变量T的具体类型。争取让编译器检查出错误,而不是留给JVM运行的时候抛出类不匹配的异常。
2、JVM如何理解泛型概念 —— 类型擦除。事实上,JVM并不知道泛型,所有的泛型在编译阶段就已经被处理成了普通类和方法。 处理方法很简单,我们叫做类型变量T的擦除(erased) 。
3、泛型代码与JVM
- ① 虚拟机中没有泛型,只有普通类和方法。
- ② 在编译阶段,所有泛型类的类型参数都会被Object或者它们的限定边界来替换。(类型擦除)
- ③ 在继承泛型类型的时候,桥方法的合成是为了避免类型变量擦除所带来的多态灾难。 无论我们如何定义一个泛型类型,相应的都会有一个原始类型被自动提供。原始类型的名字就是擦除类型参数的泛型类型的名字。
2.通过反射得到T的真实类型
// 通过反射得到T的真实类型
ParameterizedType pt = (ParameterizedType) this.getClass().getGenericSuperclass();
T的真是类型 = (Class) pt.getActualTypeArguments()[0];//取第一个泛型的类型
3.注意
原生类型 和 参数化类型
所以,如果你对自己的编程足够自信,你完全可以在写代码的时候只写原生类型而不用泛型,因为其实这只是为了编译器在检查代码的时候防止参数错误,到了编译期泛型都会被擦除,最终还是回到原生类型。
但是,并不建议这么做,因为虽然只写原生类型可以省略编译期泛型擦除这一步,但是这对性能的提升并没起多大哪怕一丁点的作用,反而可能导致我们写代码的时候由于粗心出错了而没有被IDE编译器检查出来,直到运行的时候才报错就得不偿失了。