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集合详解

原文地址:https://www.cnblogs.com/frankcui/p/13592223.html