再通过for循环遍历list集合时,怎么删除list集合中的元素

在Java中,如果你尝试在一个迭代过程中直接修改正在迭代的集合(如使用remove),可能会遇到ConcurrentModificationException异常。这是因为迭代器检测到了集合的结构性修改(比如添加或删除元素)。

要避免这个问题,有几种方法可以安全地删除列表中的元素:

方法一:使用迭代器的 remove 方法

你可以使用迭代器的 remove() 方法来移除元素。这种方法是线程安全 的,并且不会抛出 ConcurrentModificationException 异常。

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5));
Iterator<Integer> iterator = list.iterator();
while (iterator.hasNext()) {
    Integer value = iterator.next();
    if (value % 2 == 0) { // 删除所有偶数
        iterator.remove();
    }
}
System.out.println(list); // 输出 [1, 3, 5]

方法二:倒序遍历列表

另一种方法是从列表的末尾开始向前遍历并移除元素,这样就不会影响到前面尚未处理的元素的索引。

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5));
for (int i = list.size() - 1; i >= 0; i--) {
    if (list.get(i) % 2 == 0) { // 删除所有偶数
        list.remove(i);
    }
}
System.out.println(list); // 输出 [1, 3, 5]

方法三:使用 Java Stream API

如果你使用的是 Java 8 或更高版本,还可以使用流(Stream)API来处理这种情况。

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5));
list.removeIf(n -> n % 2 == 0); // 删除所有偶数
System.out.println(list); // 输出 [1, 3, 5]

每种方法都有其适用场景,选择哪种取决于具体的需求以及你对代码的可读性和性能的考虑。如果你需要在遍历的同时修改列表,请确保采用合适的方法来避免并发修改异常。

相关推荐
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠6 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦13 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠14 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82114 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q14 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒14 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
世人万千丶14 天前
成语接龙小应用 - HarmonyOS ArkUI 开发实战-TextInput与List列表-PC版本
华为·list·harmonyos·鸿蒙·鸿蒙系统