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 等等.你可以在系统中直接使用这些 ...
随机推荐
- 转:linux 安装 Elasticsearch5.6.x 详细步骤以及问题解决方案
在网上有很多那种ES步骤和问题的解决 方案的,不过没有一个详细的整合,和问题的梳理:我就想着闲暇之余,来记录一下自己安装的过程以及碰到的问题和心得:有什么不对的和问题希望及时拍砖. 第一步:环境 li ...
- shell du sh 文件大小输出
按照文件大小升序输出结果: du -sh * | sort -h 如果要逆序输出,则: du -sh * | sort -hr
- idea object is not a member of package
可能的原因: 1. pom.xml 依赖的工程没有deploy, 所有需要本地install改工程 2. 工程以来的库没有加入到 pom.xml中 3. 以上都没有问题,则右键该工程 => ma ...
- HDU5470 Typewriter (SAM+单调队列优化DP)
Typewriter Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Tota ...
- 从FPGA搞定OV7670 VGA显示 移植到 STM32F10x TFT显示 总结及疑问(高手请进)
OV7670不愧是最便宜的摄像头了最大显示像素:640*480(在VGA显示器上显示效果还不赖,用usb模块采集显示依然显著) 第一步:VGA显示 视频图像(实时)FPGA+SDRAM+OV7670= ...
- PC端、移动端页面适配方案
前言 页面自适应PC端.移动端大体上可以分为两种: 1.在同一个页面进行自适应布局,通常使用CSS3 @media 媒体查询器实现 2.两套页面,在后端进行统一适配,根据不同的浏览器UA返回对应的页面 ...
- 修改CentOS7网卡名字
需求:CentOS7网卡名字不像之前CentOS6版本的eth0,eth1这样的名字了,而是enoxxx比较长,不太容易记忆,操作也不方便!这时候就需要改网卡名字了. 1 :查看你的CentOS7 ...
- 201871010119-帖佼佼《面向对象程序设计(java)》第十二周学习总结
博客正文开头格式: 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nw ...
- nginx配置隐藏index.php
Nginx 服务器隐藏 index.php 配置 location / { try_files $uri $uri/ /index.php?$query_string; } nginx配置中t ...
- 从零开始—Socket系统调用和多态封装
1 重新搭建实验环境 前面都是用实验楼环境做的实验,偷的懒总是要还的,这一次重装环境前后花了十几个小时,踩了无数的坑. 1.1 Ubuntu和LINUX内核的区别 Ubuntu是基于LINUX内核编写 ...