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

相关推荐
wengqidaifeng20 小时前
探索数据结构(二):空间复杂度
c语言·开发语言·数据结构
Once_day20 小时前
代码训练总结(1)算法和数据结构的框架思维
数据结构·算法
鹿角片ljp20 小时前
力扣125.验证回文串-双指针
数据结构·算法
夏乌_Wx20 小时前
练题100天——DAY44:回文链表 ★★☆☆☆
数据结构
-Try hard-21 小时前
数据结构|概念及单向有头链表
数据结构·算法·vim
郝学胜-神的一滴21 小时前
Python List操作:+、+=、extend的深度解析
开发语言·数据结构·python·程序人生·架构·list
皮皮哎哟21 小时前
夯实基础:数据结构核心概念与线性表(顺序表&链表)C语言全解析 数据结构篇
c语言·数据结构·顺序表·单向链表·有头链表
蜡笔小马21 小时前
8.Packing 算法
数据结构·b树
划破黑暗的第一缕曙光21 小时前
[数据结构]:4.二叉树_堆
c语言·数据结构·二叉树·
浅念-1 天前
C语言——双向链表
c语言·数据结构·c++·笔记·学习·算法·链表