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();

原文地址:https://www.cnblogs.com/heaven-elegy/p/11929022.html

时间: 2024-07-29 14:46:48

Iterable与Collection源码学习的相关文章

Java Collection源码学习

Java集合类的顶层是Collection<E>接口, Collection接口是最基本的容器接口,继承至Iterable接口(主要通过其进行产生迭代器逐一的进行元素访问).其中的元素允许重复,可以无序. JDK没有提供直接实现Collection接口的实现类,它提供更具体的子接口如List.Set等. 继承自它的子接口包括BeanContext, BeanContextServices, BlockingDeque<E>, BlockingQueue<E>, Dequ

JAVA Collection 源码分析(一)之ArrayList

到今天为止,差不多已经工作一年了,一直在做的是javaweb开发,一直用的是ssh(sh)别人写好的框架,总感觉自己现在高不成低不就的,所以就像看看java的源码,顺便学习一下大牛的思想和架构,read and write一直是提高自己编程水平的不二法门,写博客只是记录自己的学习历程,方便回顾,写的不好的地方,请多多包含,不喜勿喷,好了废话少说,现在让我们开始我们的历程把,Let's go!!!!!!!! 想看源码无从下手,不知道有没有跟我一样感觉的人们,今天用Intellij发现了可以找出类与

Spring源码学习笔记(6)

Spring源码学习笔记(六) 前言-- 最近花了些时间看了<Spring源码深度解析>这本书,算是入门了Spring的源码吧.打算写下系列文章,回忆一下书的内容,总结代码的运行流程.推荐那些和我一样没接触过SSH框架源码又想学习的,阅读郝佳编著的<Spring源码深度解析>这本书,会是个很好的入门. 上一篇中我们梳理到 Spring 加载 XML 配置文件, 完成 XML 的解析工作,接下来我们将进入 Spring 加载 bean 的逻辑. 我们使用 Spring 获取 XML

JDK源码学习LinkedList

LinkedList是List接口的子类,它底层数据结构是双向循环链表.LinkedList还实现了Deque接口(double-end-queue双端队列,线性collection,支持在两端插入和移除元素).所以LinkedList既可以被当作双向链表,还可以当做栈.队列或双端队列进行操作.文章目录如下: 1.LinkedList的存储实现(jdk 1.7.0_51) 2.LinkedList的读取实现 3.LinkedList的性能分析 下面我们进入正题,开始学习LinkedList. L

JDK源码学习系列06----Vector

                                            JDK源码学习系列06----Vector 1.Vector简介 Vector的内部是数组实现的,它和ArrayList非常相似,最大的不同就是 Vector 是线程安全(同步)的. public class Vector<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.S

JDK源码学习----ArrayList

                                                                         JDK源码学习----ArrayList 1.ArrayList简介 ArrayList是基于Object[] 数组的,也就是我们常说的动态数组.它能很方便的实现数组的增加删除等操作. public class ArrayList<E> extends AbstractList<E> implements List<E>, R

Java多线程之JUC包:ReentrantReadWriteLock源码学习笔记

若有不正之处请多多谅解,并欢迎批评指正. 请尊重作者劳动成果,转载请标明原文链接: http://www.cnblogs.com/go2sea/p/5634701.html ReentrantLock提供了标准的互斥操作,但在应用中,我们对一个资源的访问有两种方式:读和写,读操作一般不会影响数据的一致性问题.但如果我们使用ReentrantLock,则在需要在读操作的时候也独占锁,这会导致并发效率大大降低.JUC包提供了读写锁ReentrantReadWriteLock,使得读写锁分离,在上述情

Java多线程之JUC包:Semaphore源码学习笔记

若有不正之处请多多谅解,并欢迎批评指正. 请尊重作者劳动成果,转载请标明原文链接: http://www.cnblogs.com/go2sea/p/5625536.html Semaphore是JUC包提供的一个共享锁,一般称之为信号量. Semaphore通过自定义的同步器维护了一个或多个共享资源,线程通过调用acquire获取共享资源,通过调用release释放. 源代码: /* * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to lic

JDK1.8源码学习之 HashMap.java

///JDK1.8源码学习之HashMap.java package java.util; import java.io.IOException; import java.io.InvalidObjectException; import java.io.Serializable; import java.lang.reflect.ParameterizedType; import java.lang.reflect.Type; import java.util.function.BiConsu