迭代器 Iterator 是什么?

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

java迭代器查找的唯一操作就是依靠调用next,而在执行查找任务的同时,迭代器的位置也在改变.

Iterator迭代器remove方法会删除上次调用next方法返回的元素.这也意味之remove方法和next有着很强的依赖性.如果在 调用remove之前没有调用next是不合法的 .这个接口衍生出了,java集合的迭代器.java集合的迭代器使用

{
boolean hasNext() //如果仍有元素可以迭代,则返回 true。
E next() //返回迭代的下一个元素。
void remove() //删除
default void forEach //实现了迭代器接口的类才可以使用forEach
}

javascript lambda 迭代 java 迭代器 remove_java集合

迭代器 Iterator 怎么使用?

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

class test {
public static void run() {
List list = new LinkedList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(3);
//依靠这个方法生成一个java集合迭代器
Iterator 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方法的运行方式并不是类似于数组的运行方式.

javascript lambda 迭代 java 迭代器 remove_java集合_02

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

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

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

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

参考

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