zoukankan      html  css  js  c++  java
  • Java Collection

    迭代器 Iterator 是什么?

    Java容器的顶部接口就是Iterator。是一个可以遍历集合的对象,为各种容器提供了公共的操作接口,隔离对容器的遍历操作和底层实现,从而解耦。

    1. java迭代器查找的唯一操作就是依靠调用next,而在执行查找任务的同时,迭代器的位置也在改变.
    2. Iterator迭代器remove方法会删除上次调用next方法返回的元素.这也意味之remove方法和next有着很强的依赖性.如果在 调用remove之前没有调用next是不合法的 .这个接口衍生出了,java集合的迭代器.java集合的迭代器使用
    {
       
     boolean hasNext()  //如果仍有元素可以迭代,则返回 true。 
     E next()    //返回迭代的下一个元素。 
     void remove()  //删除
     default void forEach //实现了迭代器接口的类才可以使用forEach
    }
    

    查看最新图片,请点击:https://www.processon.com/apps/58bd73cfe4b0f944a6660f38

     

    迭代器 Iterator 怎么使用?

    易错点:Iterator调用remove之前没有调用next是不合法的

    class test {
        public static void run() {
            List<Integer> list = new LinkedList<>();
            list.add(1);
            list.add(2);
            list.add(3);
            list.add(3);
           //依靠这个方法生成一个java集合迭代器<--在Colletion接口中的方法,被所有集合实现.
            Iterator<Integer> iterator = list.iterator();
           // iterator.remove();报错java.lang.IllegalStateException
            iterator.next();
            iterator.remove();//不报错,删掉了1
            System.out.println(list);//AbstractCollection类中实现的toString让list可以直接被打印出来
            while (iterator.hasNext()) {//迭代器,hasNext()集合是否为空
                Integer a = iterator.next();//可以用next访问每一个元素
                System.out.println(a);//2,3,3
            }
            for (int a : list) {//也可以使用foreach
                System.out.println(a);//2,3,3
            }
        }
        public static void main(String[] args) {
            run();
        }
    }
    

    当然你也会有点好奇,为什么 remove 方法前面必须跟着一个next方法.其实这个只能这么解释.

    迭代器的next方法的运行方式并不是类似于数组的运行方式.

     

     

    当然,这张图主要是让你理解一下.

    数组的指针指向要操作的元素上面,而迭代器却是将要操作的元素放在运动轨迹中间.

    本质来讲,迭代器的指针并不是指在元素上,而是指在元素和元素中间.

    假设现在调用remove().被删除的就是2号元素.(被迭代器那个圆弧笼盖在其中的那个元素).如果再次调用,就会报错,因为圆弧之中的2号元素已经消失,那里是空的,无法删除.

    参考

    不眠不休不写bug:java集合详解

  • 相关阅读:
    Hadoop 实现 TFIDF 计算
    关于Elasticsearch 使用 MatchPhrase搜索的一些坑
    SpringBoot jar包中资源加载问题
    gradle 将依赖打入Jar包的方法
    ES 在聚合结果中进行过滤
    Java c# 跨语言Json反序列化首字母大小写问题
    hadoop is running beyond virtual memory limits问题解决
    hadoop环境运行程序出现 Retrying connect to server 问题
    CSS的初步认识,基本选择器(CSS day1)
    day19 time模块
  • 原文地址:https://www.cnblogs.com/frankcui/p/13592223.html
Copyright © 2011-2022 走看看