使用 Java Stream 的 groupBy 计算出现次数
在 Java 中,您可以利用流来高效聚合数据。一种常见的操作是按值对项目进行分组并计算其出现次数。
示例
假设您有一个字符串列表,并且想要计算每个唯一字符串的频率。目标是创建一个映射,其中键是字符串,值是其出现次数。
带有计数收集器的 groupBy
为了实现这一点,我们可以将 groupBy 方法与计数收集器结合使用。 groupBy 方法根据指定的键将元素组织成组。在本例中,我们希望根据字符串的身份对字符串进行分组。
在此代码中,Function.identity() 获取字符串本身作为分组键,本质上保留了原始元素。 Collectors.counting() 提供了一个收集器,返回每个组中元素的数量。
结果
分组和计数后,我们得到一个具有所需数量的地图:
此映射包含原始字符串中每个唯一字符串的出现次数
效率注意事项
对于大型数据集,使用 Collectors.groupingByConcurrent 可能会提高效率。它以并行方式工作,增强了多核环境中的性能。然而,这种方法可能不适合元素顺序或线程安全至关重要的场景。
以上是如何使用流高效地统计Java中字符串的出现次数?的详细内容。更多信息请关注PHP中文网其他相关文章!