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

相关推荐
ValhallaCoder15 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
月挽清风16 小时前
代码随想录第十五天
数据结构·算法·leetcode
NEXT0617 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
小妖66620 小时前
js 实现快速排序算法
数据结构·算法·排序算法
独好紫罗兰1 天前
对python的再认识-基于数据结构进行-a003-列表-排序
开发语言·数据结构·python
wuhen_n1 天前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
2401_841495641 天前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
独好紫罗兰1 天前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_841495641 天前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
数智工坊1 天前
【数据结构-树与二叉树】4.5 线索二叉树
数据结构