这一章节我们来讨论一下超类通配符。

1.什么是超类通配符

在前一章节我们提到一种通配符,是使用<?

extends XXX>来实现的,导致了后面的一系列问题,如今我们引入还有一种通配符--超类通配符。它是使用<?

super XXX>来实现的。

样例:

package com.ray.ch13;

import java.util.ArrayList;

public class Test {
public static void main(String[] args) {
ArrayList<? super Fruit> list = new ArrayList<Fruit>();
// ArrayList<? super Fruit> list2 = new ArrayList<Apple>();//error
}
} class Fruit {
} class Apple extends Fruit {
} class Fuji extends Apple {
}

注意:使用超类通配符。前后的边界必须保持一致。不然抛异常。

2.超类通配符与上一章节的通配符有什么不同?

代码:

package com.ray.ch13;

import java.util.ArrayList;

public class Test {
public static void main(String[] args) {
ArrayList<? extends Fruit> fruits = new ArrayList<Fruit>();
fruits.add(null);// 上一章节出现的问题
ArrayList<? super Fruit> list = new ArrayList<Fruit>();
list.add(new Fruit());
list.add(new Apple());
list.add(new Fuji());
// ArrayList<? super Apple> list1 = new ArrayList<Fruit>();//编译通过
ArrayList<? super Apple> list1 = new ArrayList<Apple>();
list1.add(new Apple());
list1.add(new Fuji());
// ArrayList<? super Fuji> list2 = new ArrayList<Fruit>();//编译通过
// ArrayList<? super Fuji> list2 = new ArrayList<Apple>();//编译通过
ArrayList<? super Fuji> list2 = new ArrayList<Fuji>();
list2.add(new Fuji());
ArrayList<? super Fuji> list3 = new ArrayList<Fruit>();
list3.add(new Fuji());
}
} class Fruit {
} class Apple extends Fruit {
} class Fuji extends Apple {
}

观察上面的代码,能够发现:

(1)上一章节出现的问题就是不知道泛型的边界。从而无法add对象。

(2)使用了超类通配符。创建对象的泛型边界能够是定义时參数类型的父类(这里比較绕口,请看凝视);

(3)使用了超类通配符。就是定义了下界,能够把泛型的子类和本身类型的对象add到容器里面。

总结:这一章节注意介绍超类通配符,以及跟上一章节通配符的差别。

这一章节就到这里。谢谢。

-----------------------------------

文件夹

从头认识java-13.12 超类通配符的更多相关文章

  1. sbt Getting org.scala-sbt sbt 0.13.12 ...

    本地仓库被我搞乱了,一气之下整个删掉了本地仓库,再重启sbt卡在Getting这一步. Getting org.scala-sbt sbt 0.13.12 ... 卡住 补充sbt配置文件: 文件结构 ...

  2. Java 13 明天发布,最新最全新特性解读

    2017年8月,JCP执行委员会提出将Java的发布频率改为每六个月一次,新的发布周期严格遵循时间点,将在每年的3月份和9月份发布. 目前,JDK官网上已经可以看到JDK 13的进展,最新版的JDK ...

  3. Java 9 ← 2017,2019 Java → 13 ,都发生了什么?

    距离 2019 年结束,只剩下 35 天了.你做好准备迎接 2020 年了吗? 一到年底,人就特别容易陷入回忆和比较之中,比如说这几天, 的对比挑战就火了! 这个话题登上了微博的热搜榜,也刷爆了朋友圈 ...

  4. Java 9 ← 2017,2019 → Java 13,来看看Java两年来的变化

    距离 2019 年结束,只剩下 33 天了.你做好准备迎接 2020 年了吗? 一到年底,人就特别容易陷入回忆和比较之中,比如说这几天的对比挑战就火了! 这个话题登上了微博的热搜榜,也刷爆了朋友圈, ...

  5. Java 13 特性解读

    Java 13 特性解读    转 https://blog.csdn.net/bjweimengshu/article/details/100978383   2017年8月,JCP执行委员会提出将 ...

  6. Java 13新特性

    switch表达式 switch表达式是Java 12开始就提供的预览特性,到了Java 13仍然没有被转正.此特性可以把switch的执行结果组合到复合表达式中进行运算. import java.t ...

  7. 2019年9月17 发布 Java 13

    Java 13 明天发布,最新最全新特性解读   2017年8月,JCP执行委员会提出将Java的发布频率改为每六个月一次,新的发布周期严格遵循时间点,将在每年的3月份和9月份发布. 目前,JDK官网 ...

  8. Java 13 发布了!

    点击上方蓝色链接,关注并"设为星标" Java干货,每天及时推送 通告一下,Java 13 09/17 发布了,尝鲜地址: https://www.oracle.com/techn ...

  9. Java 13 即将发布,新特性必须抢先看!

    作者:h4cd 本文转载自开源中国(ID:oschina2013) 由于 Java 现在采取"半年发布一次新版本"的模式,所以 Java 12 的下一个版本 Java 13/JDK ...

随机推荐

  1. Android开发之EditText 详解(addTextChangedListener监听用户输入状态)

    为了实现像qq或者微信输入框的效果,当在 EditText输入字符串时发送按钮显示,当输入框字符消除掉时按钮改变.所以这时候我就要用到addTextChangedListener 用它来监听用户输入状 ...

  2. 查看suse系统版本

    cat /etc/*-release OR lsb_release -d

  3. sicily 1004. 简单哈希

    Description 使用线性探测法(Linear Probing)可以解决哈希中的冲突问题,其基本思想是:设哈希函数为h(key) = d, 并且假定哈希的存储结构是循环数组, 则当冲突发生时,  ...

  4. python3.x 学习笔记1(基础知识)

    1.python模块: 标准库和第三方库,第三方库需要下载安装 2.模块sys: 命令 功能 sys.stdin 标准输入流sys.stdout  标准输出流sys.stderr           ...

  5. C#共享WIFI能通过代码控制给连接的移动端分配IP么

    用C#创建了一个虚拟WIFI,但是能不能通过代码来给连接上的移动端分配各自的IP.之前都是自动分配的IP.望大神们赐教 C#共享WIFI能通过代码控制给连接的移动端分配IP么 >> csh ...

  6. CSS W3SCHOOLS

    https://www.w3schools.com/csS/css3_buttons.asp

  7. Scala之面向对象

    1. Scala基础练习 不使用str.toLong,str.toInt/Integer.valueOf()/Long.valueOf/Integer.parseInt()等,将字符串"12 ...

  8. The Future Of ReactiveCocoa by Justin Spahr-Summers

    https://www.bilibili.com/video/av9783052?from=search&seid=14165903430339282774

  9. PHP 数组转字符串,字符串转数组

    explode将字符串分割为数组: $str = explode( ',',$str); 第一个参数为字符串的分界符,例如1,2,3,4. 第二个是需要分割的数组 分割后就是 array( 1 , 2 ...

  10. 题解 CF1027D 【Mouse Hunt】

    这道题原本写了一个很复杂的DFS,然后陷入绝望的调试. 看了一下题解发现自己完全想复杂了. 这里大概就是补充一些题解没有详细解释的代码吧... (小声BB)现在最优解rank4(话说$O2$负优化什么 ...