zoukankan      html  css  js  c++  java
  • 48. 迭代器注意事项

    迭代器中的几个方法:

    hasNext()   判断是否存在下一个元素

    next()     输出指针当前指向的元素,后指针向下移动一位

    add()     在当前指针指向的位置上添加指定元素

    下面我们来看一下代码

    public static void main(String[] args) {
            List list = new ArrayList();
            list.add("张三");
            list.add("李四");
            list.add("王五");
            
            ListIterator listit = list.listIterator();
            while(listit.hasNext()) {
                System.out.println(listit.next());
                listit.add("aa");
            }
            System.out.println(list);
            
        }

    首先第一点,我们可以知道add方法添加成功了。可以按照我们的想法应该是死循环啊?

    开始指针指向的是0,当运行next方法的时候指针指向了1,再运行add添加了“aa”,我们可以知道添加成功了,但是为什么没有输出aa呢?还有为什么没有死循环?

    我们来看看源代码:

    add的源代码

    public void add(E e) {
                checkForComodification();
    
                try {
                    int i = cursor;
                    ArrayList.this.add(i, e);
                    cursor = i + 1;
                    lastRet = -1;
                    expectedModCount = modCount;
                } catch (IndexOutOfBoundsException ex) {
                    throw new ConcurrentModificationException();
                }
            }

    我们可以发现每当add的时候cursor都加1,这说说明跳过了我们添加的元素。没有输出的原因是,防止上面死循环出现

    下面我们再看一段代码:

    public static void main(String[] args) {
            List list = new ArrayList();
            list.add("张三");
            list.add("李四");
            list.add("王五");
            
            ListIterator listit = list.listIterator();
            while(listit.hasNext()) {
                System.out.println(listit.next());
                list.add("aa");
            }
            System.out.println(list);
        }

    注意:这样写会报错的,如果这样写,那么添加的元素会添加在集合的末尾处,会直接跳过集合中的所有元素,这个是不允许的

  • 相关阅读:
    Luogu P1004 方格取数
    Luogu P1896 [SCOI2005]互不侵犯
    Luogu P1879 [USACO06NOV]玉米田Corn Fields 【状压dp模板】
    高精度模板(结构体)
    【模板】快读
    vue input框type=number 保留两位小数自定义组件
    elementui表格表头合并
    将excle表中得数据生成insert语句插入到数据库中
    数据库基本语法
    ztree 数组和树结构互转算法
  • 原文地址:https://www.cnblogs.com/zjdbk/p/8985566.html
Copyright © 2011-2022 走看看