27

鉴于我有一些函数需要两个参数并返回一个值,是否可以将 Map 转换为 Stream 中的 List 作为非终端操作?我找到的最近的方法是在地图上使用 forEach 创建实例并将它们添加到预定义的列表中,然后从该列表中启动一个新的流。还是我只是错过了什么?

例如:经典的“在长长的单词列表中找到 3 个最常出现的单词”

wordList.stream().collect(groupingBy(Function.identity, Collectors.counting))).

(现在我想流式传输该地图的 entrySet)

sorted((a,b) -> a.getValue().compareTo(b.getValue))).limit(3).forEach(print...
4

2 回答 2

56

您应该获取entrySet地图并将条目粘合到二进制函数的调用中:

inputMap.entrySet().stream().map(e->myFun(e.getKey(),e.getValue()));

上面的结果是一个T实例流。

更新

您的附加示例证实了以下评论中讨论的内容:group by并且sort本质上是终端操作。必须完全执行它们才能产生输出的第一个元素,因此将它们作为非终端操作涉及在性能/内存占用方面不会购买任何东西。

碰巧 Java 8 定义sorted为非终端操作,但是该决定可能导致欺骗性代码,因为该操作将阻塞,直到它接收到所有上游元素,并且在接收时必须保留它们。

于 2014-01-20T11:52:13.317 回答
0

您还可以使用以下技术将 Hashmap 条目转换为 ArrayList,

ArrayList list = hashMap.values();
于 2021-11-03T10:27:31.390 回答