我理解java的泛型是假泛型,只在编译期有效,为什么用如下方式能获得父类的泛型。
class Child extends Parent<String>
//Child类中可通过如下代码获取到带<String>的Parent
((ParameterizedType)getClass().getGenericSuperclass().getActualTypeArguments()[0];
class Test<String>
如果当前类带了泛型,那么怎么获取?或说获取不到
我理解java的泛型是假泛型,只在编译期有效,为什么用如下方式能获得父类的泛型。
class Child extends Parent<String>
//Child类中可通过如下代码获取到带<String>的Parent
((ParameterizedType)getClass().getGenericSuperclass().getActualTypeArguments()[0];
class Test<String>
如果当前类带了泛型,那么怎么获取?或说获取不到
你好!一下代码能拿到当前类所带的泛型类型了哦!当然这是你当前类是有定义泛型的前提下才会有,没有定义泛型是会报 数组越界的哦。
getClass().getTypeParameters()[0];
15 回答6.9k 阅读
2 回答3.3k 阅读✓ 已解决
3 回答7k 阅读✓ 已解决
5 回答4.7k 阅读
3 回答5.2k 阅读
4 回答2.4k 阅读
2 回答2.3k 阅读✓ 已解决
java的范型是擦除法,就是只是在编译的时候检测类型是否安全,而在运行时这些范型类型已经被擦除,因此运行时使用反射时无法获知范型的类型,比如:
java在编译的时候会检测所有加入到list里面的都是String类型,编译后的class文件中是不会有范型的信息,所以运行的时候通过反射API是无法得知list的范型是String的。
而范型子类不一样:
java在编译的时候会检测父类的范型信息,因为子类声明了范型的类型并且在子类的代码中会使用到该类型,所以java会在生成的class中记录该子类声明的范型类型,所以只有在这种情况下运行时通过反射API可以取到该范型的类型。