标签:并行 时代 vat 指定 ext over imp action 多核
Iterable接口是Java 集合框架的顶级接口,实现此接口使集合对象可以通过迭代器遍历自身元素。
// T:迭代器返回的类型
public interface Iterable<T> {
// 返回一个内部元素为T类型的迭代器
Iterator<T> iterator();
// 对Iterable中的元素进行指定的操作
default void forEach(Consumer<? super T> action) {
Objects.requireNonNull(action);
for (T t : this) {
action.accept(t);
}
}
// 在Iterable元素上创建一个分割器
default Spliterator<T> spliterator() {
return Spliterators.spliteratorUnknownSize(iterator(), 0);
}
}
后两个方法是Java8后新添加的,forEach(Consumer action)是为了方便遍历操作集合内的元素。spliterator()则提供了一个可以并行遍历元素的迭代器,以适应现在cpu多核时代并行遍历的需求。其中我们可以看下default修饰符,这也是Java8后新出现的,我们知道,如果我们给一个接口新添加一个方法,那么所有他的具体子类都必须实现此方法,为了能给接口拓展新功能,而又不必每个子类都要实现此方法,Java8新加了default关键字,被其修饰的方法可以不必由子类实现,并且由dafault修饰的方法在接口中有方法体,这打破了Java之前对接口方法的规范。
进行迭代遍历的时候我们需要注意这种情况,就是在遍历的过程中,如果我们对元素进行添加删除,那么会造成并行修改异常。对于这种情况,我们应当使用迭代器Iterator内部的remove()方法,而不是使用集合list直接删除元素。
import java.util.Iterator;
public class MyCollection<E> implements Iterable<E> {
@SuppressWarnings("unchecked")
@Override
public Iterator iterator() {
return new MyIterator();
}
private class MyIterator implements Iterator<E>{
@Override
public boolean hasNext() {
return false;
}
@Override
public E next() {
return null;
}
}
}
标签:并行 时代 vat 指定 ext over imp action 多核
原文地址:https://www.cnblogs.com/feiqiangsheng/p/11184196.html