gpt4 book ai didi

lambda - 映射结果上的 Collectors.groupingBy 到嵌套映射

转载 作者:行者123 更新时间:2023-12-02 03:53:34 25 4
gpt4 key购买 nike

我有以下代码

 Map<Long,String> timeMap= new HashMap<>();
Map<Boolean, List<Map.Entry<Long,String>>> output= timeMap.entrySet().parallelStream()
.filter(map -> map.getKey()-Instant.now().toEpochMilli()>120000)
.collect(Collectors.groupingBy(o -> o.getKey()<600000));

我希望我的输出是一个 map 嵌套 map

 Map<Boolean, List<Map.Entry<Long,String>>> output --> Map<Boolean, Map<Long,String>> output

有人可以帮我编写一个 BiFunction 来实现此目的吗?

目前我正在使用以下方法来生成输出。

 Map<Long, String> trueMap = output.get(true).stream()
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue));
Map<Long, String> falseMap = output.get(false).stream()
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue));

Map<Boolean,Map<Long,String>> booleanMapMap = new HashMap<>();
booleanMapMap.put(true,trueMap);
booleanMapMap.put(false,falseMap);

最佳答案

嵌套的收集器将是更好的方法:

Map<Boolean, Map<Long, String>> collect = timeMap.entrySet().stream()
.filter(e -> e.getKey() - Instant.now().toEpochMilli() > 120_000)
.collect(
Collectors.partitioningBy(e -> e.getKey() < 600_000,
Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)
));

关于lambda - 映射结果上的 Collectors.groupingBy 到嵌套映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52040152/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com