如何实现Java迭代器中删除元素的实例操作详解?

2026-04-19 17:461阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计546个文字,预计阅读时间需要3分钟。

如何实现Java迭代器中删除元素的实例操作详解?

通过Iterator,我们可以遍历集合中的元素。那么,在遍历过程中,如果我们遇到不需要的元素,能否在遍历的时候顺便将其删除呢?答案是当然可以。在Iterator中有一个remove函数,专门用于删除遍历到的元素。

我们知道通过Iterator,可以对集合中的元素进行遍历。那么在其中遇到我们不需要的元素时,可不可以在遍历的时候顺便给删除呢?答案是当然可以。在Iterator下有一个remove函数,专门用于删除的操作。下面我们就remove进行讲解,然后对删除元素方法进行说明,最后带来实例的展示。

1.Iterator中的remove

void remove():删除迭代器刚越过的元素

从基础集合中移除这个迭代器返回的最后一个元素(可选操作)。两个线程中都删除,保证线程的同步。

如何实现Java迭代器中删除元素的实例操作详解?

2.删除元素说明

(1)迭代器遍历方式, 适用于连续内存存储方式,比如数组、 ArrayList(其实 ArrayList底层实现也是数组形式)。 缺点是只能从头开始遍历, 优点是可以边遍历边删除

(2)arraylist每次遍历的时候会去判断该集合是否被修改过,调用的方法是checkForComodification()。 如果被修改过ConcurrentModificationException异常。

(3)如何判断是否修改呢,主要是通过维护2个变量来实现,modCount记录了修改次数,expectedModCount记录期望修改次数。 通过iterator.remove()进行的删除操作,会同时修改modCount、ConcurrentModificationException; 而通过list.remove(object/index),则只会修改modCount。 这也是fast-fail机制

3.删除实例

Iterator it=list.iterator(); while(it.hasNext()){ Object e=it.next(); if("b".equals(e)){ it.remove(); } } System.out.println(list);

Iterator中的remove()实例代码:

import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class IteratorRemoveDemo { public static void main(String[] args) { List list = new ArrayList(5); for (int i = 0; i < 5; i++) { list.add(i); } System.out.println(list); // 移除最后访问的元素 iterator.next(); iterator.next(); iterator.remove(); System.out.println(list); } } /*输出: [0, 1, 2, 3, 4] [0, 2, 3, 4] */

到此这篇关于java迭代器中删除元素的实例操作详解的文章就介绍到这了,更多相关java迭代器中删除元素的操作内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

本文共计546个文字,预计阅读时间需要3分钟。

如何实现Java迭代器中删除元素的实例操作详解?

通过Iterator,我们可以遍历集合中的元素。那么,在遍历过程中,如果我们遇到不需要的元素,能否在遍历的时候顺便将其删除呢?答案是当然可以。在Iterator中有一个remove函数,专门用于删除遍历到的元素。

我们知道通过Iterator,可以对集合中的元素进行遍历。那么在其中遇到我们不需要的元素时,可不可以在遍历的时候顺便给删除呢?答案是当然可以。在Iterator下有一个remove函数,专门用于删除的操作。下面我们就remove进行讲解,然后对删除元素方法进行说明,最后带来实例的展示。

1.Iterator中的remove

void remove():删除迭代器刚越过的元素

从基础集合中移除这个迭代器返回的最后一个元素(可选操作)。两个线程中都删除,保证线程的同步。

如何实现Java迭代器中删除元素的实例操作详解?

2.删除元素说明

(1)迭代器遍历方式, 适用于连续内存存储方式,比如数组、 ArrayList(其实 ArrayList底层实现也是数组形式)。 缺点是只能从头开始遍历, 优点是可以边遍历边删除

(2)arraylist每次遍历的时候会去判断该集合是否被修改过,调用的方法是checkForComodification()。 如果被修改过ConcurrentModificationException异常。

(3)如何判断是否修改呢,主要是通过维护2个变量来实现,modCount记录了修改次数,expectedModCount记录期望修改次数。 通过iterator.remove()进行的删除操作,会同时修改modCount、ConcurrentModificationException; 而通过list.remove(object/index),则只会修改modCount。 这也是fast-fail机制

3.删除实例

Iterator it=list.iterator(); while(it.hasNext()){ Object e=it.next(); if("b".equals(e)){ it.remove(); } } System.out.println(list);

Iterator中的remove()实例代码:

import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class IteratorRemoveDemo { public static void main(String[] args) { List list = new ArrayList(5); for (int i = 0; i < 5; i++) { list.add(i); } System.out.println(list); // 移除最后访问的元素 iterator.next(); iterator.next(); iterator.remove(); System.out.println(list); } } /*输出: [0, 1, 2, 3, 4] [0, 2, 3, 4] */

到此这篇关于java迭代器中删除元素的实例操作详解的文章就介绍到这了,更多相关java迭代器中删除元素的操作内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!