java stream 多个filter_Java Stream API中多个和单个filter有性能差异吗?

本文探讨了在Java Stream API中使用一个filter与多个连续filter在性能上的差异。通过实例代码和测试,发现单个filter和多个filter在没有其他操作介入时性能基本一致。但当多个filter之间加入sorted操作时,将多个filter合并为一个可以得到更好的性能。文章建议理解Stream API的工作原理以优化代码效率。
摘要由CSDN通过智能技术生成

背景:

在做发布前code review时,看到下面这段代码

workShiftOrderDTOS = workShiftOrderDTOS.stream()

.filter(x -> x.getShiftDO().isFullDayWorkShift() == false)

.collect(Collectors.toList());

开发同学新增了1个筛选条件

workShiftOrderDTOS = workShiftOrderDTOS.stream()

.filter(x -> x.getShiftDO().isFullDayWorkShift() == false)

.filter(x -> x.getShiftDO().canViewShift())

.collect(Collectors.toList());

思考

由上面的code review,思考下面2段对集合进行filter的代码,返回结果是一致的,性能上有差异嘛?

@Data

class Employee {

private String gender;

private Integer age;

}

public static void main(String[] args) {

List employees = Lists.newArrayList();

// >1个filter

employees.stream()

.filter(employee -> employee.getAge() > 32)

.filter(e

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值