JAVA泛型继承关系

相同泛型参数的继承关系

当泛型参数相同时,类型的继承关系取决于原生类型。

List<String> list = new ArrayList<>();
// 编译通过
Collection<String> father = list;
// 编译失败
Collection<Integer> father = list;

泛型类型相同时的类继承关系
公共父类

不同泛型参数的继承关系

不同泛型参数的类的继承关系并不是由泛型参数的关系决定的,但可以使用通配符来限定关系。

  • 通配符的上下界定义,只能用于返回值或形参,不能在类或方法声明中
// 编译正常
List<? super Object> superObjList = new ArrayList<>();
List<? extends Object> extendObjList = new ArrayList<>();

// 编译失败 Unexpected wildcard
public <? extends String> void print(String msg) {
  System.out.println(msg);
}
  • 具体泛型T的上下界定义,只能存在于类或方法声明中,不能在返回值中
// 编译失败 Unexpected bound
List<T super String> superList = new ArrayList<>();
List<T extends Number> extendList = new ArrayList<>();

// 编译正常
public <U extends String> U print(U msg) {
   System.out.println(msg);
    return msg;
}

泛型继承关系

泛型数组

  • 遵循原生类型的继承关系
    String extends Object,那么String[] extexds Object[]成立。但String和String[]是两个不同的类型,不存在任何关系
  • 类型转换并不关心底层存储的真实类型,而是关注数组初始声明定义的类型
String[] s1 = {"abc", "efg", "hij"};
Object[] s2 = s1;
String[] s3 = (String[]) s2;  // 可以强转

Object[] s4 = {"abc", "efg", "hij"};
String[] s5 = (String[]) s4;  // 报错,不可以强转

基于以上的事实,在初始化泛型数组时,可以使用下面的代码

// 底层数组类型是int[]
int[] nums = (int[]) Array.newInstance(int.class, 10);
// 底层数组类型是String[]
String[] strings = (String[]) Array.newInstance(String.class, 10);
// 底层数组类型是String[]
Object[] origins = strings;
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值