首先来说说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
慢慢学习,慢慢积累!如有错误,还请指出