遍历list的同时修改list

在Java中,遍历列表的同时修改列表有多种方式,每种方式都有其适用的场景和优缺点。以下是几种常见的方法:

  1. 使用Iterator的remove()方法

    • 这是官方推荐的方式,可以在迭代过程中安全地删除元素,而不会抛出ConcurrentModificationException
    • 示例代码:
      List<String> list = new ArrayList<>();
      list.add("A");
      list.add("B");
      list.add("C");
      
      Iterator<String> iterator = list.iterator();
      while (iterator.hasNext()) {
          String element = iterator.next();
          if (element.equals("B")) {
              iterator.remove();
          }
      }
      
  2. 使用CopyOnWriteArrayList

    • 这是一个线程安全的列表,允许在遍历的同时进行修改。在修改时会创建一个新的数组,迭代器在旧数组上遍历。
    • 示例代码:
      List<String> list = new CopyOnWriteArrayList<>();
      list.add("A");
      list.add("B");
      list.add("C");
      
      for (String element : list) {
          if (element.equals("B")) {
              list.remove(element);
          }
          System.out.println(element);
      }
      
  3. 从后往前遍历并删除元素

    • 通过手动管理索引,从后往前遍历列表,删除元素时不会影响前面元素的索引。
    • 示例代码:
      List<String> list = new ArrayList<>();
      list.add("A");
      list.add("B");
      list.add("C");
      
      for (int i = list.size() - 1; i >= 0; i--) {
          if (list.get(i).equals("B")) {
              list.remove(i);
          }
      }
      
  4. 使用并发集合

    • ConcurrentLinkedQueue等,设计上支持并发修改,适用于多线程环境。
    • 示例代码:
      ConcurrentLinkedQueue<String> queue = new ConcurrentLinkedQueue<>();
      queue.add("A");
      queue.add("B");
      queue.add("C");
      
      Iterator<String> iterator = queue.iterator();
      while (iterator.hasNext()) {
          String element = iterator.next();
          if (element.equals("B")) {
              queue.remove(element);
          }
      }
      
  5. 使用removeIf()等集合操作方法

    • 不是在传统迭代过程中修改,但可以达到类似效果。
    • 示例代码:
      List<String> list = new ArrayList<>();
      list.add("A");
      list.add("B");
      list.add("C");
      
      list.removeIf(element -> element.equals("B"));
      

选择哪种方式取决于具体的需求和场景。在单线程环境下,可以选择上述任何一种方式;在多线程环境下,可能需要更复杂的同步机制或选择线程安全的集合类。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

需要重新演唱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值