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

相关推荐
八解毒剂12 分钟前
查找-从二分查找到二叉排序树
数据结构·c++·算法
_日拱一卒2 小时前
LeetCode:78子集
数据结构·算法·leetcode·职场和发展
FuckPatience3 小时前
C# new List<T>(IEnumerable<T> collection),链表初始化时传入已存在链表
链表·c#·list
東隅已逝,桑榆非晚4 小时前
数据结构:算法效率与复杂度分析详解
数据结构·笔记·算法
半夜修仙4 小时前
分治思想对数组进行排序-归并排序
数据结构·算法·排序算法
小欣加油4 小时前
leetcode3635 最早完成陆地和水上游乐设施的时间II
数据结构·c++·算法·leetcode
变量未定义~5 小时前
排列数字、 n-皇后问题
数据结构·算法
·白小白5 小时前
C++ STL 容器 list 底层结构详解
开发语言·c++·list
暖阳华笺5 小时前
【高频考点】回溯(暴力搜索)
数据结构·c++·算法·回溯法
Chensay.5 小时前
链表的基本操作(C语言版)
数据结构·链表