JAVA8如何在遍历List时安全地删除元素

1.removeif

removeIf是Java8 Collecttion的一个默认方法;删除满足给定谓词的这个集合的所有元素

复制代码
  public static void main(String[] args) {
        List<Integer> list = new ArrayList<>();
        list.addAll(Arrays.asList(10, 9, 8, 7, 6, 5, 4, 3, 2, 1));
 
        //Java8遍历和删除只有一短行就实现了
        list.removeIf(value -> value % 2 == 0);
        System.out.println(list);
    }

2.filter

filter都产生一个新的StatelessOp,也就新的流,通过opWrapSink不断匹配条件,当为false时则标记此流元素可过滤,生成新的List,不能直接操作原List

复制代码
   public static void main(String[] args) {
        List<Integer> list2 = new ArrayList<>();
        list2.addAll(Arrays.asList(10, 9, 8, 7, 6, 5, 4, 3, 2, 1));
        //java8这里的遍历和删除只有一短行就实现了 代码简洁,高效,线程安全。
        list2 = list2.stream().filter(value -> value % 2 != 0).collect(Collectors.toList());
        System.out.println(list);
    }

removeIf和filter方法都能达到过滤/删除元素的作用。

removeIf是条件为true则过滤此元素,false则保留。而filter则是条件为false过滤此元素,而true则保留。

因为removeIf返回的是boolean,而filter是个intermediate operation,需要terminal operation最终来处理流,如果只是单单只做删除/过滤操作, removeIf会快些。

相关推荐
生成论实验室7 小时前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
阿文的代码库8 小时前
线段树入门:算法分析
数据结构·算法
悠仁さん8 小时前
数据结构 树 二叉树 堆 (堆的模拟实现篇)
数据结构
此生决int9 小时前
算法从入门到精通——位运算
数据结构·c++·算法·蓝桥杯
计算机安禾9 小时前
【算法分析与设计】第4篇:分治策略的理论框架与经典案例
数据结构·算法·排序算法
Kiling_07049 小时前
面向对象和集合编程题 ( 二 )
java·开发语言·数据结构·算法
过期动态9 小时前
【LeetCode 热题 100】两数之和— 暴力法与哈希表法详解
java·数据结构·算法·leetcode·散列表
Pointer Pursuit9 小时前
哈希表的实现
数据结构·哈希算法·散列表
故事和你919 小时前
洛谷-【动态规划1】动态规划的引入4
开发语言·数据结构·c++·算法·动态规划·图论
qq_2965532710 小时前
[特殊字符] 旋转排序数组中的高效搜索:从线性到二分查找的进阶之路
数据结构·算法·搜索引擎·分类·柔性数组