zoukankan      html  css  js  c++  java
  • ListIterator 迭代器

    1.介绍 

    listiterator 是一个强大的iterator子类型,能用于各种list类的访问.比如 双向移动,修改指定下表的值. 比lierator多了很多功能,算是iterator一个加强版本.

    2.使用

    List<Integer> list = new ArrayList<>();
            list.add(1);
            list.add(2);
            list.add(3);
            ListIterator<Integer> it = list.listIterator();
            while (it.hasNext()) {
                System.out.println(it.next()); //  1 2 3
            }
            while (it.hasPrevious()) {
                System.out.println(it.previous()); // 3  2  1
            }
            
            it = list.listIterator(1);
            it.next();// 要先next 才能设置
            it.set(5);
            System.out.println(list); // [1, 5, 3]

    可以看到,listIterator 可以通过 previous() 方法 从后往前遍历,自由控制遍历的方向.

    还可以通过  listIterator(int index)  获取指定下表开始的迭代器,并通过 set  方法 修改 .

    这里有个注意事项:  在set方法执行前需要先执行 next 方法, 为什么要这样做, 需要分析下源码

    private class Itr implements Iterator<E> {
            int cursor;       // 下一个要返回的元素
            int lastRet = -1; // 上一个要返回的元素,-1代表没有
            int expectedModCount = modCount;
    
            Itr() {}
    
            public boolean hasNext() {
                return cursor != size;
            }
    
            @SuppressWarnings("unchecked")
            public E next() {
                checkForComodification();
                int i = cursor;
                if (i >= size)
                    throw new NoSuchElementException();
                Object[] elementData = ArrayList.this.elementData;
                if (i >= elementData.length)
                    throw new ConcurrentModificationException();
                cursor = i + 1;
                return (E) elementData[lastRet = i]; // 这里 lastRet 赋值为 0
            }
    
            public void remove() {
                if (lastRet < 0)
                    throw new IllegalStateException();
                checkForComodification();
    
                try {
                    ArrayList.this.remove(lastRet);
                    cursor = lastRet;
                    lastRet = -1;
                    expectedModCount = modCount;
                } catch (IndexOutOfBoundsException ex) {
                    throw new ConcurrentModificationException();
                }
            }
     public void set(E e) {
                if (lastRet < 0) // lastRet如果为 -1  则抛出异常
                    throw new IllegalStateException();
                checkForComodification();
    
                try {
                    ArrayList.this.set(lastRet, e);
                } catch (IndexOutOfBoundsException ex) {
                    throw new ConcurrentModificationException();
                }
            }

    可以看到 lastRet  这个参数默认是 -1, 而  set() 方法在最开始检测了这个变量,所以需要 在 next()  方法中把 last Ret赋值后才不会为 -1, next()  return 方法可见 cursor 最后赋值给了 lastRet;

    remove()方法同理.

  • 相关阅读:
    Python之路第一课Day1--随堂笔记
    前端面试题汇总
    全国计算机二级python备考
    小程序体检评分优化
    自己配置webpack报错总结
    npm install 报错npm WARN tar ENOENT: no such file or directory和npm ERR! cb() never called!可能的原因
    vue 里面使用sass进行代码复用mixin简单用法
    用openlayers初始化地图碰到过的 地图不显示的问题 VUE
    element el-table表格树状图全选/取消 子节点无法选中问题
    element 树形结构自定义节点图标
  • 原文地址:https://www.cnblogs.com/lishuaiqi/p/11022924.html
Copyright © 2011-2022 走看看