集合源码学习(一):Collection

首先来说说Collection,它是集合的接口,代表着就是一个集合,可以往里面装东西,装各种物品等。

定义头

它的定义头如下:

public interface Collection<E> extends Iterable<E>

介绍Iterable接口

定义头

public interface Iterable<T>

构造方法

/*返回当前类的遍历器(iterator),可以利用其来遍历*/
Iterator<T> iterator();

其他方法

/**
从java8开始有的,用于给本集合的每一个元素执行特定的动作(action),自己实现action方法。其中该集合必须实现Consumer接口,并且是T类的父类,即下限是T类。    Consumer仅仅是一个接口,里面包含两个方法
    #accept()方法,抽象方法,用于实现具体动作
    #forEach方法
        */
    default void forEach(Consumer<? super T> action) {
        Objects.requireNonNull(action);
        for (T t : this) {
            action.accept(t);
        }
    }

泛型上下限

scala使用[+T],表示协变 对应java的 <? extends T>
[-T],表示逆变 对应java的 <? super T>

Consumer类一些知识
Consumer类是java8新增的,代表着新特征函数接口@FunctionalInterface

@FunctionalInterface
public interface Consumer<T> {

    /**
     执行某一个具体动作
     */
    void accept(T t);

    /**
    这是java新增的用于组合两个函数的函数式编程方法,这个方法的简单意思就是先执行调用者,再执行参数,return后面 Lambda 表达式是一个另一篇文章会详细介绍
     */
    default Consumer<T> andThen(Consumer<? super T> after) {
        Objects.requireNonNull(after);
        return (T t) -> { accept(t); after.accept(t); };
    }
}

关于compose和andThen函数compose和andThen
以及 Lambda 表达式Lambda表达式

Collection里面方法

Collection里面的方法都是抽象方法,具体实现都是由实现的子类具体去实现的,例如有List和Set两种不同的子类,则两种不同的add和remove也相应的不同。
具体方法

    int size(); //返回集合大小
    boolean isEmpty(); //判断集合是否为空
    boolean contains(Object o); //判断集合是否含有某一个元素,不同的类判定标准不同,看具体实现
    Iterator<E> iterator(); //返回集合的一个Iterator,并不会保证顺序性
    Object[] toArray(); //返回集合相对应的Object数组,如果集合有序的,则返回的数组一定也是有相应顺序的。
    /**拥有上一个toArray所有规则,并且传入参数a,如果a足够大,则把转化后的数组放入a中且从第一个开始,到Collection的最后一个,一次装入数组a中,对于a中后面的则不变,否则返回一个新的a**/
    <T> T[] toArray(T[] a);
    boolean add(E e); //往集合里面增加一个元素
    boolean remove(Object o);  //往集合里面删除一个特定元素
    boolean containsAll(Collection<?> c); //判断一个集合是否包含某个元素集合的所有
    boolean addAll(Collection<? extends E> c);  //将集合c加入本集合中
    boolean removeAll(Collection<?> c);  //将既在本集合又在c集合中元素全部清除,返回不含有公共元素的本集合

    /**
     * 从java8开始,删除所有符合预测(Predicate)的集合元素,关于Predicate具体细节可以自己实现。
     * Predicate是一个方法接口
     */
    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;
    }
    boolean retainAll(Collection<?> c); //保留本集合和c集合相同的元素,即保留并集
    void clear();  //清空集合
    /**
    *注意有个规则,当利用hash表来实现的集合时,
    *hash不相同,equals一定false
    *equals为false时,hash可能为true也可能为false,也就是比较equals时,一定会先比较hash值
    **/
    boolean equals(Object o);//比较
    int hashCode(); //去hash值

    /**
     * 从java8开始
     * 返回一个可分割的迭代器,关于可分割迭代器,可以看我后面文章
     */
    @Override
    default Spliterator<E> spliterator() {
        return Spliterators.spliterator(this, 0);
    }

    /**
     *返回当前集合的流,如果当前集合无法返回spliterator,则需要重写此方法
     * @since 1.8
     */
    default Stream<E> stream() {
        return StreamSupport.stream(spliterator(), false);
    }

    /**
     * 返回一个可并行流
     * @since 1.8
     */
    default Stream<E> parallelStream() {
        return StreamSupport.stream(spliterator(), true);
    }

java8开始的Stream类Stream
java8开始的Spliterator类Spliterator

慢慢学习,慢慢积累!如有错误,还请指出

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值