JDK1.7源码分析01-Collection
同步发布:http://www.yuanrengu.com/index.php/20180221.html
Java的集合类主要由两个接口派生而出:Collection和Map。Collection是一个接口,它主要的两个分支为List和Set,Map的介绍会在后面的系列中进行详细的分析。如下图所示为Collection接口、子接口及其实现类的继承树。

源码分析如下:
package java.util; /**
* Collection继承了迭代器的接口,即整个集合类都采用了迭代器模式
*/
public interface Collection<E> extends Iterable<E> {
// Query Operations /**
* 返回集合的大小。
* 如果集合的大小超过Integer.MAX_VALUE,则返回Integer.MAX_VALUE
*/
int size(); /**
* 判断集合是否为空
*/
boolean isEmpty(); /**
* 判断集合中是否有元素o。
* 这里要特别注意下元素o是否与集合里的元素类型兼容,以及o是否为null
*/
boolean contains(Object o); /**
* 返回集合中元素的迭代器,但不能保证返回顺序(除非集合指定了顺序)
*/
Iterator<E> iterator(); /**
* 返回一个数组(包含集合中所有的元素)。
* 如何集合中的元素是有序的,则返回的数组中的元素也是有序的。
* 这个方法可用于集合与数组之间的转换
*/
Object[] toArray(); /**
* 以数组形式返回指定数组类型的集合元素
*/
<T> T[] toArray(T[] a); // Modification Operations /**
* 用于向集合里添加元素
* 如果集合对象被添加操作改变了则返回true
*/
boolean add(E e); /**
* 删除元素
*/
boolean remove(Object o); // Bulk Operations /**
* 用来判断是否含有指定集合c中的所有元素
*/
boolean containsAll(Collection<?> c); /**
* 将指定集合c中的所有元素添加至调用者的集合中
*/
boolean addAll(Collection<? extends E> c); /**
* 删除集合中所包含的c里面的元素
*/
boolean removeAll(Collection<?> c); /**
* 保留与集合c中相同的元素(即移除与指定集合不同的元素)
* 相当于把调用该方法的集合变成该集合和集合c的交集
*/
boolean retainAll(Collection<?> c); /**
* 清除集合里的所有元素,集合长度变为0
*/
void clear(); // Comparison and hashing /**
* 判断与指定元素是否相等
*/
boolean equals(Object o); /**
* 返回集合的哈希码值
*/
int hashCode();
}
Collection继承了Iterable,如图所示:

Iterable源码分析如下:
/**
* 迭代器接口
*/
public interface Iterable<T> { /**
* 返回元素类型为T的迭代器
*/
Iterator<T> iterator();
}
其中Iterator的源码如下:
/**
* 迭代器接口类
*/
public interface Iterator<E> { /**
* 如果被迭代的集合元素还没有被遍历,则返回true
*/
boolean hasNext(); /**
* 返回集合里的下一个元素
*/
E next(); /**
* 删除集合里上一次next方法返回的元素
*/
void remove();
}
Iterator仅用于遍历集合,Iterator本身并不提供装对象的能力。如果需要创建Iterator对象,则必须有一个被迭代的集合。Iterator必须依附于Collection对象,如有一个Iterator对象,则必然有一个与之关联的Collection对象。特别要注意的是,当使用Iterator对集合元素进行迭代时,Iterator并不是把集合元素本身传给了迭代变量,而是把集合元素的值传给了迭代变量,所以修改迭代变量的值对集合元素本身没有任何影响。
JDK1.7源码分析01-Collection的更多相关文章
- JDK1.8源码分析01之学习建议(可以延伸其他源码学习)
序言:目前有个计划就是准备看一下源码,来提升自己的技术实力.同时现在好多面试官都喜欢问源码,问你是否读过JDK源码等等? 针对如何阅读源码,也请教了我的老师.下面就先来看看老师的回答,也许会有帮助呢. ...
- 【JUC】JDK1.8源码分析之ArrayBlockingQueue(三)
一.前言 在完成Map下的并发集合后,现在来分析ArrayBlockingQueue,ArrayBlockingQueue可以用作一个阻塞型队列,支持多任务并发操作,有了之前看源码的积累,再看Arra ...
- 集合之TreeSet(含JDK1.8源码分析)
一.前言 前面分析了Set接口下的hashSet和linkedHashSet,下面接着来看treeSet,treeSet的底层实现是基于treeMap的. 四个关注点在treeSet上的答案 二.tr ...
- 【1】【JUC】JDK1.8源码分析之ArrayBlockingQueue,LinkedBlockingQueue
概要: ArrayBlockingQueue的内部是通过一个可重入锁ReentrantLock和两个Condition条件对象来实现阻塞 注意这两个Condition即ReentrantLock的Co ...
- 【集合框架】JDK1.8源码分析HashSet && LinkedHashSet(八)
一.前言 分析完了List的两个主要类之后,我们来分析Set接口下的类,HashSet和LinkedHashSet,其实,在分析完HashMap与LinkedHashMap之后,再来分析HashSet ...
- 【集合框架】JDK1.8源码分析之HashMap(一) 转载
[集合框架]JDK1.8源码分析之HashMap(一) 一.前言 在分析jdk1.8后的HashMap源码时,发现网上好多分析都是基于之前的jdk,而Java8的HashMap对之前做了较大的优化 ...
- 【集合框架】JDK1.8源码分析之ArrayList详解(一)
[集合框架]JDK1.8源码分析之ArrayList详解(一) 一. 从ArrayList字表面推测 ArrayList类的命名是由Array和List单词组合而成,Array的中文意思是数组,Lis ...
- 集合之LinkedHashSet(含JDK1.8源码分析)
一.前言 上篇已经分析了Set接口下HashSet,我们发现其操作都是基于hashMap的,接下来看LinkedHashSet,其底层实现都是基于linkedHashMap的. 二.linkedHas ...
- 集合之HashSet(含JDK1.8源码分析)
一.前言 我们已经分析了List接口下的ArrayList和LinkedList,以及Map接口下的HashMap.LinkedHashMap.TreeMap,接下来看的是Set接口下HashSet和 ...
- 【1】【JUC】JDK1.8源码分析之ReentrantLock
概要: ReentrantLock类内部总共存在Sync.NonfairSync.FairSync三个类,NonfairSync与FairSync类继承自Sync类,Sync类继承自AbstractQ ...
随机推荐
- iOS enum 定义与使用
枚举其实很重要,特别是在应用开发初期,服务器端数据格式需要更改得情况下,枚举和宏都能是程序简洁,并且改动小. 网上有个人写的言简意赅,适合初学 转自:http://blog.csdn.net/ysy4 ...
- 【开发技术】常用正则表达式大全!(例如:匹配中文、匹配html)
匹配中文字符的正则表达式: [u4e00-u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉字在内):[^x00-xff] 评注:可以用来计算字符串的长度 ...
- nginx中location匹配顺序
一.location语法 语法: Syntax: location [ = | ~ | ~* | ^~ ] uri { ... } location @name { ... } Default: - ...
- java面向对象的三大特性——封装
封装 封装从字面上来理解就是包装的意思,专业点就是信息隐藏,是指利用抽象数据类型将数据和基于数据的操作封装在一起,使其构成一个不可分割的独立实体,数据被保护在抽象数据类型的内部,尽可能地隐藏内部的细节 ...
- JSTL遇到的问题
1.jstl 中不可以用关键字命名 例如class new. 2.jstl取值的问题 如果jstl通过对象.属性取值 属性值中包括特殊字符(例如:31/20180131195356867.txt&qu ...
- python_鸡兔同笼问题
鸡兔同笼问题 -- 今有雉兔同笼,上有三十五头,下有九十四足,问雉兔各几何? --鸡和兔在一个笼子里,从上面数,有35个头:从下面数,有94只脚.问笼中各有几只鸡和兔 如何逻辑整理? -- 鸡头和兔子 ...
- laravel5.5 when()的用法
当你在使用where语句有前提条件时,比如某值为1的时候才执行where子句,否则不执行,这个时候,laravel5.5新出了一个简便方法when($arg,fun1[,fun2]). 具体用法如下: ...
- 输入和输出--java序列化机制
对象的序列化 什么是Java对象的序列化? 对象序列化的目标是将对象保存到磁盘上,或允许在网络中直接传输对象.对象序列化机制允许把内存中的Java对象转换成与平台无关的二进制流,从而保存或者传输.其他 ...
- Failed to get D-Bus connection: Operation not permitted解决
docker中安装centos无法使用systemctl命令管理进程,报以下错误: Failed to get D-Bus connection: Operation not permitted 原因 ...
- Mysql编译安装及优化
采取编译安装的方法,其好处为:编译安装与平台无关,安装的MySQL目录独立,维护起来方便,而且拥有更好的性能. 环境:CentOS release 6.9 (Final) x86_64 1)下载my ...