Java8之Iterator接口

接口的作用为提供指定类型的迭代器。

public interface Iterator<E> {

    // 每探测是否还有下一个元素
    boolean hasNext();

    // 返回当前迭代元素 ,迭代游标后移
    E next();

    // 删除最近一次已近迭代出出去的那个元素  
    default void remove() {
        throw new UnsupportedOperationException("remove");
    }

    // 为每个剩余的元素执行给定的操作
    default void forEachRemaining(Consumer<? super E> action) {
        Objects.requireNonNull(action);
        while (hasNext())
            action.accept(next());
    }
}

总结

迭代器迭代出的对象也是引用的拷贝,还是引用类型。那么如果集合中保存的元素是可变类型的,那么可以通过迭代出的元素修改原集合中的对象。

for循环和迭代器Iterator对比

ArrayList对随机访问比较快,而for循环中的get()方法,采用的即是随机访问的方法,因此在ArrayList里,for循环较快。
LinkedList则是顺序访问比较快,iterator中的next()方法,采用的即是顺序访问的方法,因此在LinkedList里,使用iterator较快。
从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素。
而Iterator适合访问链式结构,因为迭代器是通过next()来定位的。可以访问没有顺序的集合。

猜你喜欢

转载自www.cnblogs.com/feiqiangsheng/p/11184240.html