gpt4 book ai didi

java - groupingBy 和 filter 一步到位

转载 作者:行者123 更新时间:2023-11-29 07:36:45 27 4
gpt4 key购买 nike

我有一个 Stream<String> ,我想要一个 Map<Integer, String> .让我们调用我的分类器函数 getKey(String) - 它可能很昂贵。有时它会返回零,这意味着该字符串应该被丢弃并且不包含在结果映射中。

所以,我可以使用这段代码:

Stream<String> stringStream;
Map<Integer, String> result =
stringStream.collect(Collectors.groupingBy(this::getKey, Collectors.joining());
result.remove(0);

这首先将不需要的字符串添加到以零为键的映射中,然后将其删除。可能有很多。有没有一种优雅的方法可以避免首先将它们添加到 map 中?

我不想在分组之前添加过滤步骤,因为那将意味着执行决策/分类代码两次。

最佳答案

您说过调用 getKey 的开销很大,但您仍然可以在过滤元素之前预先映射流中的元素。在这种情况下,对 getKey 的调用只会执行一次。

Map<Integer, String> result =
stringStream.map(s -> new SimpleEntry<>(this.getKey(s), s))
.filter(e -> e.getKey() != 0)
.collect(groupingBy(Map.Entry::getKey, mapping(Map.Entry::getValue, joining())));

请注意,标准 API 中没有元组类。您可以推出自己的一个或使用 AbstractMap.SimpleEntry 作为替代。

或者,如果您认为第一个版本创建了很多条目,您可以使用 collect 方法,您自己提供供应商、累加器和组合器。

Map<Integer, String> result = stringStream
.collect(HashMap::new,
(m, e) -> {
Integer key = this.getKey(e);
if(key != 0) {
m.merge(key, e, String::concat);
}
},
Map::putAll);

关于java - groupingBy 和 filter 一步到位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34748306/

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