stream流处理有相同数据下使用filter过滤获取最新的数据

该文介绍了一种利用JavaStreamAPI处理列表数据的方法,通过并行流排序和过滤,以获取每个独特键值的最新记录。具体操作包括根据特定字段反向排序,使用distinctByKey方法消除重复并保留第一条出现的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如何通过stream流快速处理相同数据下,只想要最新的那条数据

filter过滤无往不利 🥰

List<IndexStockBlockDTO> list = IndexStockBlockList.parallelStream()
//先排序最新的
.sorted(Comparator.comparing(IndexStockBlockDTO::getSource).reversed())
//此处会根据Scode 获取到第一个出现的,过滤其他的
.filter(distinctByKey(IndexStockBlockDTO::getScode))
.collect(Collectors.toList());
//根据最新数据排序后获取相同数据下最新的一个
    private static <T> Predicate<T> distinctByKey(Function<? super T, ?> keyExtractor) {
        Map<Object, Boolean> seen = new ConcurrentHashMap<>();
        return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null;
    }

希望对你有所帮助…期待 三连 😊

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值