泛型:上边界和通配符的使用以及对ArrayList的学习
---------------
public class Wildcord {
public static void main(String[] args) {
/**
* 类引用结构说明Person类,Student和Teacher类都是继承于Person, BadStudent类继承于Student类
*/
List<? extends Person> list = new ArrayList<Person>();
list.add(null);
// list.add(new Person("person1", 1));
/*
* 上面一行编译报错:原因是list是一个List的对象, 这个List里面的元素可以是任何继承于Person的实例,
* 也就是我们规定了list的元素的上边界是Person, 但是Person有两个继承(况且还有Person这个父类在),
* Student和Teacher,List要求内部元素必须一致, 所以这里java已经判断不出你到底需要什么元素了。
*/
List<? extends BadStudent> list1 = new ArrayList<BadStudent>();
list1.add(null);
// list1.add(new BadStudent("fusd", 23));
/*
* 上面一行编译仍然报错:原因是什么呢?这里我门几乎已经确定list1里面的元素是唯一一类了
* 但是仍然不可以,这就是声明java本省就告诉我们不可以这样用,因为随时会有类可能继承自
* BadStudent啊,具体源码我们没看过,但问题的原因应该就是这样
*/
List<BadStudent> list2 = new ArrayList<BadStudent>();
list2.add(null);
list2.add(new BadStudent("fusd", 23));
System.out.println(list2.size());
/*
*这里就正常了
*/
List<? extends Person> list3 = new ArrayList<Student>();
List<? extends Person> list4 = new ArrayList<Teacher>();
list3.add(null);
// list3.add(new Student("chenkh", 24));
/*
* 上面两个类似,在创建实例的时候没有任何问题,但是一旦涉及add操作,就会出问题
*/
System.out.println(list3.size() + "\t" + list4.size());
}
}
class Person {
String name;
int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
}
class Student extends Person {
public Student(String name, int age) {
super(name, age);
}
}
瞬间发现,源码阅读涉及的东西真的好多。
这里自己的总结真心乱。
就这样吧。。。。。。。
所以我们应该很好奇add方法到底做了什么限制,现在看源码!
参考博客:Java中List实现之ArrayList(讲的非常详细,关于ArrayList的添加元素等源码分析,现在的新版本jdk源码有些改动,但是基本是这样的)
所以最终我们并没有在源码中发现关于add方法有没有什么检查,所以暂时感觉add中检查这个元素是否可以作为添加项应该是编译器做的事情。
泛型:上边界和通配符的使用以及对ArrayList的学习的更多相关文章
- Java中的泛型 (上) - 基本概念和原理
本节我们主要来介绍泛型的基本概念和原理 后续章节我们会介绍各种容器类,容器类可以说是日常程序开发中天天用到的,没有容器类,难以想象能开发什么真正有用的程序.而容器类是基于泛型的,不理解泛型,我们就难以 ...
- Java编程的逻辑 (35) - 泛型 (上) - 基本概念和原理
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- Java泛型之上、下界通配符的理解(适合初学)
泛型的由来 为什么需要泛型 Java的数据类型一般都是在定义时就需要确定,这种强制的好处就是类型安全,不会出现像弄一个ClassCastException的数据给jvm,数据安全那么执行的clas ...
- Java泛型解析(02):通配符限定
Java泛型解析(02):通配符限定 考虑一个这种场景.计算数组中的最大元素. [code01] public class ArrayUtil { public static <T&g ...
- 【Java心得总结三】Java泛型上——初识泛型
一.函数参数与泛型比较 泛型(generics),从字面的意思理解就是泛化的类型,即参数化类型.泛型的作用是什么,这里与函数参数做一个比较: 无参数的函数: public int[] newIntAr ...
- java_泛型,设置类型通配符的上限
package ming; import java.util.ArrayList; import java.util.Collection; import java.util.List; class ...
- JAVA泛型之<? extends T>:(通配符上限)和<? super T>(通配符下限)
一.通配符上限和通配符下限接受的类型 通配符上限:<? extends T> 通配符下限:<? super T> 以下代码是测试结果,注释为解释说明 package xayd. ...
- 泛型与非泛型集合类的区别及使用例程,包括ArrayList,Hashtable,List<T>,Dictionary<Tkey,Tvalue>,SortedList<Tkey,Tvalue>,Queue<T>,Stack<T>等
泛型与非泛型集合类在C#程序中是非常重要的一个基础概念,这里列一个表来进行对比: 非泛型集合类 泛型集合类 描述 ArrayList List<T> 表示具有动态大小的对象数组 Hasht ...
- 上四条只是我目前总结菜鸟们在学习FPGA时所最容易跑偏的地
长期以来很多新入群的菜鸟们总 是在重复的问一些非常简单但是又让新手困惑不解的问题.作为管理员经常要给这些菜鸟们普及基础知识,但是非常不幸的是很多菜鸟怀着一种浮躁的心态来学习 FPGA,总是急于求成. ...
随机推荐
- 持续集成:TeamCity 的安装和使用
TeamCity 本文初衷 让大家了解持续集成(CI),以及入门了解 JetBrains 家的 TeamCity 的一些简单实用. TeamCity 的一些复杂使用我暂时也不会,一样也是要看文档的,所 ...
- MVVMLight - Messenger 2
本篇介绍MvvmLight中一个重要的东东,那就是Messenger. (一)Messenger的基本组成 Messenger类用于应用程序的通信,接受者只能接受注册的消息类型,另外目标类型可以被指定 ...
- node.js搭建https服务器
HTTPS简介 HTTPS:(全称:Hypertext Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版. ...
- javascript预编译和执行过程总结
javascript相对于其它语言来说是一种弱类型的语言,在其它如java语言中,程序的执行需要有编译的阶段,而在javascript中也有类似的“预编译阶段”(javascript的预编译是以代码块 ...
- CSS3之 :nth-child(n)语法讲解
语法: E:nth-child(n){ sRules } * 匹配父元素索引为n的子元素E :nth-child(n) 让你匹配到父元素的任一子元素: Figure 1:<section id= ...
- android 动态库死机调试方法 .
原地址:http://blog.csdn.net/andyhuabing/article/details/7074979 这两种方法都不是我发明了,都是网上一些高手公共出来的调试方法,无奈找不到出处的 ...
- ES6,先知道这些必会的才行
变量声明 const 和 let 不要用 var,而是用 const 和 let,分别表示常量和变量.不同于 var 的函数作用域,const 和 let 都是块级作用域. const DELAY = ...
- sqlserver查询表字段描述(转)
原文地址:https://blog.csdn.net/changhong009/article/details/29587063 --快速查看表结构(比较全面的) SELECT CASE WHEN c ...
- Hadoop生态体系
Hadoop路线 HDFS 分布式文件系统 MapReduce 分布式编程框架 ZooKeeper 分布式协调框架 Hive 非关系型数据仓库 Flume 日志采集框架
- 表单校验常用原生js库
1.字符串去除左右空格继承形式// 除去左右空格String.prototype.Trim = function() { return this.replace(/(^\s*)|(\s*$)/g, & ...