我理解java的泛型是假泛型,只在编译期有效,为什么用如下方式能获得父类的泛型。class Child extends Parent<String>//Child类中可通过如下代码获取到带<String>的Parent((ParameterizedType)getClass().getGenericSuperclass().getActualTypeArguments()[0];class Test<String>如果当前类带了泛型,那么怎么获取?或说获取不到
2 回答
冉冉说
TA贡献1877条经验 获得超1个赞
java的范型是擦除法,就是只是在编译的时候检测类型是否安全,而在运行时这些范型类型已经被擦除,因此运行时使用反射时无法获知范型的类型,比如:
List<String> list = new ArrayList<>();
java在编译的时候会检测所有加入到list里面的都是String类型,编译后的class文件中是不会有范型的信息,所以运行的时候通过反射API是无法得知list的范型是String的。
而范型子类不一样:
class Child extends Parent<String>
java在编译的时候会检测父类的范型信息,因为子类声明了范型的类型并且在子类的代码中会使用到该类型,所以java会在生成的class中记录该子类声明的范型类型,所以只有在这种情况下运行时通过反射API可以取到该范型的类型。
翻阅古今
TA贡献1780条经验 获得超5个赞
你好!一下代码能拿到当前类所带的泛型类型了哦!当然这是你当前类是有定义泛型的前提下才会有,没有定义泛型是会报 数组越界的哦。
getClass().getTypeParameters()[0];
添加回答
举报
0/150
提交
取消