zoukankan      html  css  js  c++  java
  • Java基础之Iterator接口

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

    查看源码

    package java.util;
    import java.util.function.Consumer;
    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循环中ArrayList的get()方法是随机访问的方法,因此在ArrayList里,for循环较快。
    LinkedList顺序访问比较快,Iterator中的next()方法是顺序访问的方法,因此在LinkedList里,使用Iterator较快。
    从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素。
    而Iterator适合访问链式结构,因为迭代器是通过next()方法来定位的。

  • 相关阅读:
    【mybatis】02-spring集成
    【Spring】xxAware
    【性能调优】Arthas
    【算法】其他算法(字典树Trie等)
    【多线程】JDK源码类图
    POJ-1251-Jungle Roads
    Prim算法模板
    敌兵布阵-线段树(1)
    hdu-1541-Stars (树状数组)
    母牛生小牛
  • 原文地址:https://www.cnblogs.com/feiqiangsheng/p/11184240.html
Copyright © 2011-2022 走看看