Java泛型擦除的总结

泛型擦除

定义的泛型只在编译时生效,运行时不生效。


原因一:JDK1.5及1.5之前都是没有泛型的概念的,JDK1.5之后引入了泛型的概念并为了与之前的JDK版本兼容,所以引入了泛型擦除的概念。在编译时进行代码检查,防止运行时出现报错。不用Object进行强转,节省性能。
原因二:若对每个泛型类型都生成不同的目标代码,现有10个不同泛型的List,就要生成10份字节码,这样会造成不仅造成代码膨胀,而且一份字节码对应一个Class对象,占据大量的内存。
规则:当定义的泛型没上届的时候,编译后会自动转化为Object,当定义的泛型又上届时,编译后会自动转化为最上游的父类。

泛型擦除导致的两大经典问题的解决方案
泛型有3类:泛型类、泛型接口、泛型方法(还没遇到)。但无论是哪种都会造成泛型擦除,而这也造成了问题:

问题1:由于泛型擦除,导致无法在 泛型类 中获取实际泛型类型
解决方法:使用匿名内部类
问题2:由于泛型擦除,导致无法在 泛型接口 进行 接口回调 之后获取实际泛型类型
解决方法:使用匿名内部类
原理:

例子:

class A<T, ID> {  
}  
  
class B extends A<String, Integer> {  
}  
  
public class Generic {  
    public static void main(String[] args) {  
        ParameterizedType parameterizedType = (ParameterizedType) B.class.getGenericSuperclass();  
        
    Type[] actualTypeArguments = parameterizedType.getActualTypeArguments();  
    for(Type actualTypeArgument: actualTypeArguments) {  
        System.out.println(actualTypeArgument);  
    }  
    }  
}  

// 输出:
class java.lang.String
class java.lang.Integer

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值