Iterable与Collection源码学习
接口 - Iterable<T> - 可迭代
描述
实现本接口的类,其对象可以被迭代.同时支持forEach语法
方法
Iterator<T> iterator()
类型
抽象方法
描述
返回一个用于执行迭代的java.util.Iterator对象
代码
Iterator<T> iterator();
default void forEach(Consumer<? super T> action)
类型
抽象默认方法
描述
遍历所有元素并分别传递给action方法
代码
default void forEach(Consumer<? super T> action) {
Objects.requireNonNull(action);
for (T t : this) {
action.accept(t);
}
}
default Spliterator<T> spliterator()
类型
抽象默认方法
描述
返回一个Spliterator<T>对象
代码
default Spliterator<T> spliterator() {
return Spliterators.spliteratorUnknownSize(iterator(), 0);
}
接口 - Collection<E>
继承
Iterable
实现
描述
规定了所有集合需要实现的方法
方法
int size()
类型
抽象方法
描述
返回当前集合的元素数量.当超过Integer.MAX_VALUE时,返回Integer.MAX_VALUE.
代码
int size();
isEmpty()
类型
抽象方法
描述
当前集合中不包含任何元素时,返回true
代码
boolean isEmpty();
contains(Object o)
类型
抽象方法
描述
当前集合中包含一个或以上的指定元素时,返回true.否则返回false
代码
boolean contains(Object o);
toArray()
类型
抽象方法
描述
返回一个包含当前集合中所有元素的数组.如果当前集合是有序集合,则这个数组中的元素顺序应该与此有序集合中的顺序相同.
同时,返回的数组必须是一个新端的数组.可以让调用者自由的修改返回数组的结构.而不影响本集合.
代码
Object[] toArray();
toArray(T[] a)
类型
抽象方法
描述
与toArray()相似.返回数据类型使用运行时类型(也就是这里的T).
当参数a可以容纳当前集合中的元素时,此方法会将当前集合内的元素放入参数a中,并在防止最后一个元素的再后面的一个位置设置为null.
当参数a无法容纳当前集合中的元素时,会返回一个新数组
代码
<T> T[] toArray(T[] a);
add(E e)
类型
抽象方法
描述
添加元素到当前集合中.当集合被修改时,将会返回true.否则返回false
在源码的注释中,提到了对于null,重复元素,与一些特殊情况下的处理措施.如不再返回false而是抛出异常等.这要看具体的实现了.
代码
boolean add(E e);
remove(Object o)
类型
抽象方法
描述
删除集合中的指定元素.当集合被更改时,返回true
代码
boolean remove(Object o);
containsAll(Collection<?> c)
类型
抽象方法
描述
给定集合中的所有元素均在当前集合中存在时,返回true
代码
boolean containsAll(Collection<?> c);
addAll(Collection<? extends E> c)
类型
抽象方法
描述
添加给定集合中的全部元素到当前集合中
这里源码注释中提出了一些为确认的情况.
- 参数
c在操作中被改变(这里一般是多线程共用一个对象时引起的). - 参数
c就是当前集合(OOM~).
代码
boolean addAll(Collection<? extends E> c);
removeAll(Collection<?> c)
类型
抽象方法
描述
删除当前集合中的出现在参数c集合中的全部元素
代码
boolean removeAll(Collection<?> c);
removeIf(Predicate<? super E> filter)
类型
抽象默认方法
描述
根据Predicate(断言),删除全部元素
这里直接使用iterator(),进行迭代,断言,删除操作
代码
default boolean removeIf(Predicate<? super E> filter) {
Objects.requireNonNull(filter);
boolean removed = false;
final Iterator<E> each = iterator();
while (each.hasNext()) {
if (filter.test(each.next())) {
each.remove();
removed = true;
}
}
return removed;
}
retainAll(Collection<?> c)
类型
抽象方法
描述
删除掉当前集合中,不包含在参数c集合中的全部元素
代码
boolean retainAll(Collection<?> c);
clear()
类型
抽象方法
描述
清除集合中的全部元素
代码
void clear();
equals(Object o)
类型
抽象方法
描述
以重写的方式,将java.lang.Object.equals方法设置为抽象方法.约束子类实现equals方法
代码
boolean equals(Object o);
hashCode()
类型
抽象方法
描述
以重写的方式,将java.lang.Object.hashCode方法设置为抽象方法.约束子类实现hashCode方法
代码
int hashCode();
Iterable与Collection源码学习的更多相关文章
- Java集合专题总结(1):HashMap 和 HashTable 源码学习和面试总结
2017年的秋招彻底结束了,感觉Java上面的最常见的集合相关的问题就是hash--系列和一些常用并发集合和队列,堆等结合算法一起考察,不完全统计,本人经历:先后百度.唯品会.58同城.新浪微博.趣分 ...
- 源码学习之ASP.NET MVC Application Using Entity Framework
源码学习的重要性,再一次让人信服. ASP.NET MVC Application Using Entity Framework Code First 做MVC已经有段时间了,但看了一些CodePle ...
- JDK源码学习系列05----LinkedList
JDK源码学习系列05----LinkedList 1.LinkedList简介 LinkedList是基于双向链表实 ...
- JDK源码学习系列04----ArrayList
JDK源码学习系列04----ArrayList 1. ...
- 【 js 基础 】【 源码学习 】源码设计 (持续更新)
学习源码,除了学习对一些方法的更加聪明的代码实现,同时也要学习源码的设计,把握整体的架构.(推荐对源码有一定熟悉了之后,再看这篇文章) 目录结构:第一部分:zepto 设计分析第二部分:undersc ...
- Spring源码学习-容器BeanFactory(三) BeanDefinition的创建-解析Spring的默认标签
写在前面 上文Spring源码学习-容器BeanFactory(二) BeanDefinition的创建-解析前BeanDefinition的前置操作中Spring对XML解析后创建了对应的Docum ...
- Underscore.js 源码学习笔记(上)
版本 Underscore.js 1.9.1 一共 1693 行.注释我就删了,太长了… 整体是一个 (function() {...}()); 这样的东西,我们应该知道这是一个 IIFE(立即执行 ...
- 【 js 基础 】【 源码学习 】源码设计 (更新了backbone分析)
学习源码,除了学习对一些方法的更加聪明的代码实现,同时也要学习源码的设计,把握整体的架构.(推荐对源码有一定熟悉了之后,再看这篇文章) 目录结构:第一部分:zepto 设计分析 第二部分:unders ...
- Asp.NetCore源码学习[2-1]:日志
Asp.NetCore源码学习[2-1]:日志 在一个系统中,日志是不可或缺的部分.对于.net而言有许多成熟的日志框架,包括Log4Net.NLog.Serilog 等等.你可以在系统中直接使用这些 ...
随机推荐
- 【并发编程】ThreadLocal的兄弟InheritableThreadLocal
本博客系列是学习并发编程过程中的记录总结.由于文章比较多,写的时间也比较散,所以我整理了个目录贴(传送门),方便查阅. 并发编程系列博客传送门 引子 public class InheritableT ...
- 西瓜哥:公有云也“All-Flash”?
本文转载自 高端存储知识 Gartner在2018年Market Insight: Preparing for the SSD Rise and HDD Demise一文中指出:当闪存介质降到HDD每 ...
- ios instancetype与id区别
我们都知道未知类型的的对象可以用id关键字表示,那为什么还会再有一个instancetype呢? instancetype能返回相关联的类型(使那些非关联返回类型的方法返回所在类的类型):而id 返回 ...
- mac office软件的安装与破解
1.mac office 软件的安装及破解 http://10176523.cn/archives/29/ 下载后安装 切记不要登录 然后用这个文件 破解
- python2和python3编码问题
欢迎加入python学习交流群 667279387 一.什么是编解码 1.什么是unicode 2.编码方式 二.python中的编解码 1.python2 (1).encode() 和 .decod ...
- Vue - 简单实现一个命令式弹窗组件
前言 在日常工作中弹窗组件是很常用的组件,但用得多还是别人的,空闲时间就自己来简单实现一个弹窗组件 涉及知识点:extend.$mount.$el 使用方式: this.$Confirm({ titl ...
- MySQL 05
目录 事务 基本概念 四大特性(ACID) 使用方法 存储引擎 视图 基本概念 使用方法 触发器 基本概念 使用方法 存储过程 基本概念 使用方法 数据备份 备份 导入 函数 事务 基本概念 事务: ...
- Python3 函数进阶2
目录 迭代器 可迭代对象 迭代器对象 总结和补充 列表推导式 字典生成式 zip()函数 递归 迭代器 迭代器是访问容器类数据类型元素的一种方式 迭代器是一个可以记住遍历的位置的对象 迭代器对象从容器 ...
- 大数据学习笔记——Java篇之集合框架(ArrayList)
Java集合框架学习笔记 1. Java集合框架中各接口或子类的继承以及实现关系图: 2. 数组和集合类的区别整理: 数组: 1. 长度是固定的 2. 既可以存放基本数据类型又可以存放引用数据类型 3 ...
- Java集合类框架的最佳实践?
根据应用的需要选择合适的集合对性能是非常重要的.如果一个集合的元素数量是固定的,而且我们能够提前知道固定的数量,那么就可以使用数组,而不是ArrayList. 每个集合都可以设置初始容量,如果我们提前 ...