在List循环迭代时删除List中的元素问题。

本文探讨了Java中Iterator的工作原理及其如何处理并发修改的情况。通过具体的代码示例解释了为何直接修改迭代中的集合会导致ConcurrentModificationException异常,并给出了正确的迭代删除元素的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

面试时被问及的一个问题,因为没遇到过,不清楚怎么回答。现在有时间特意整理一下。

Iterator 是工作在一个独立的线程中,并且拥有一个 mutex 锁。 Iterator 被创建之后会建立一个指向原来对象的单链索引表,当原来的对象数量发生变化时,这个索引表的内容不会同步改变,所以当索引指针往后移动的时候就找不到要迭代的对象,所以按照 fail-fast 原则 Iterator 会马上抛出 java.util.ConcurrentModificationException 异常。
所以 Iterator 在工作的时候是不允许被迭代的对象被改变的。但你可以使用 Iterator 本身的方法 remove() 来删除对象, Iterator.remove() 方法会在删除当前迭代对象的同时维护索引的一致性。

package cn.test;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class Test2 {
 public static void main(String[] args) {
  List<String> alist=new ArrayList<String>();
     alist.add("abc");
     alist.add("abd");
     alist.add("abe");
     alist.add("abc");
     alist.add("abc");
     alist.add("cba");
     
     //以下后报错 java.util.ConcurrentModificationException 
     for (String string : alist) {
      if("abc".equals(string)){
       alist.remove("abc");
      }
     }
     //以下这种方法会出现删除不完全的问题。
     for (int i = 0; i < alist.size(); i++) {
       System.out.println("begin:list-size()"+alist.size());
      if("abc".equals(alist.get(i))){
       alist.remove(i);
      }
       System.out.println("end:list-size()"+alist.size());
      }
     System.out.println(alist.toString());
     //----这才是正取做法
     System.out.println(alist.size());//输出6
     for (Iterator it = alist.iterator(); it.hasNext();) {                 
       Object element=it.next();
       if("abc".equals(element)){
          it.remove();
       }
     }
      System.out.println(alist.size());//输出3
  }
}

转载于:https://my.oschina.net/u/1470043/blog/523084

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值