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会快些。

相关推荐
蠢蠢的打码2 小时前
8584 循环队列的基本操作
数据结构·c++·算法·链表·图论
无问8174 小时前
数据结构-排序(冒泡,选择,插入,希尔,快排,归并,堆排)
java·数据结构·排序算法
Lenyiin4 小时前
《 C++ 修炼全景指南:十 》自平衡的艺术:深入了解 AVL 树的核心原理与实现
数据结构·c++·stl
slandarer5 小时前
MATLAB | R2024b更新了哪些好玩的东西?
java·数据结构·matlab
king_machine design5 小时前
matlab中如何进行强制类型转换
数据结构·算法·matlab
头发尚存的猿小二5 小时前
树——数据结构
数据结构·算法
紫钺-高山仰止6 小时前
【Matlab】matlab 结构体使用方法
数据结构·算法·matlab
shan_shmily6 小时前
算法知识点———并查集
数据结构·算法
终末圆7 小时前
MyBatis动态SQL中的`if`标签使用【后端 19】
java·数据结构·数据库·sql·算法·spring·mybatis
MogulNemenis7 小时前
力扣150题——位运算
数据结构·算法·leetcode