在Java中如何使用Collectors收集流结果_Collectors类使用技巧

Collectors是Java 8 Stream API中用于数据收集的核心工具类,提供toList、toSet实现元素收集,summing、averaging、summarizing支持数值聚合,groupingBy、partitioningBy实现分组与分区,joining、mapping、collectingAndThen支持字符串拼接、类型转换和结果封装,通过下游收集器组合实现复杂操作,提升代码简洁性与可读性。

在java中如何使用collectors收集流结果_collectors类使用技巧

在Java 8引入的Stream API中,Collectors 是一个非常强大的工具类,用于将流中的元素收集到集合、分组、聚合等。它配合 stream().collect() 方法使用,可以简洁高效地处理数据。掌握 Collectors 的常见用法和技巧,能大幅提升代码可读性和开发效率。

1. 收集到集合:toList、toSet、toMap

最常见的需求是把流中的元素收集到一个集合中。Collectors 提供了多种工厂方法:

toList():收集为 List toSet():收集为 Set(自动去重) toCollection(构造器):自定义集合类型,如 LinkedList、TreeSet 等示例:

List names = users.stream()    .map(User::getName)    .collect(Collectors.toList());Set uniqueNames = users.stream()    .map(User::getName)    .collect(Collectors.toSet());TreeSet sortedNames = users.stream()    .map(User::getName)    .collect(Collectors.toCollection(TreeSet::new));

2. 聚合操作:summing、averaging、summarizing

对数值型字段进行统计时,Collectors 提供了便捷的聚合方法:

summingInt/Long/Double:求和 averagingInt/Long/Double:求平均值 summarizingInt/Long/Double:返回一个包含 count、sum、min、max、average 的摘要对象示例:

int totalAge = users.stream()    .collect(Collectors.summingInt(User::getAge));DoubleSummaryStatistics stats = users.stream()    .collect(Collectors.summarizingDouble(User::getSalary));System.out.println(stats.getAverage());System.out.println(stats.getMax());

3. 分组与分区:groupingBy、partitioningBy

按条件对数据进行分类是常见需求,Collectors 提供了灵活的分组方式:

Git版本控制与工作流 中文WORD版 Git版本控制与工作流 中文WORD版

篇文章是针对git版本控制和工作流的总结,如果有些朋友之前还没使用过git,对git的基本概念和命令不是很熟悉,可以从以下基本教程入手: Git是分布式版本控制系统,与SVN类似的集中化版本控制系统相比,集中化版本控制系统虽然能够令多个团队成员一起协作开发,但有时如果中央服务器宕机的话,谁也无法在宕机期间提交更新和协同开发。甚至有时,中央服务器磁盘故障,恰巧又没有做备份或备份没及时,那就可能有丢失数据的风险。感兴趣的朋友可以过来看看

Git版本控制与工作流 中文WORD版 0 查看详情 Git版本控制与工作流 中文WORD版

立即学习“Java免费学习笔记(深入)”;

groupingBy(Function):按某个属性或函数结果分组,返回 Map groupingBy(Function, downstream):支持二级收集器,比如分组后求和 partitioningBy(Predicate):按布尔条件分为两组(true/false)示例:

// 按年龄分组Map<Integer, List> byAge = users.stream()    .collect(Collectors.groupingBy(User::getAge));// 按性别分组,并统计每组人数Map countByGender = users.stream()    .collect(Collectors.groupingBy(User::getGender,         Collectors.counting()));// 按薪资是否高于5000分区Map<Boolean, List> highEarnerPartition = users.stream()    .collect(Collectors.partitioningBy(u -> u.getSalary() > 5000));

4. 自定义收集与joining、mapping

除了基础操作,Collectors 还支持字符串拼接、类型转换等高级功能:

joining(CharSequence):将元素拼接成字符串,可指定分隔符、前缀、后缀 mapping(Function, Collector):先转换元素类型,再用下游收集器处理 collectingAndThen:在收集完成后执行额外操作示例:

// 拼接用户名,逗号分隔String namesStr = users.stream()    .map(User::getName)    .collect(Collectors.joining(", ", "[", "]"));// 先转大写,再收集为列表List upperNames = users.stream()    .collect(Collectors.mapping(u -> u.getName().toUpperCase(),         Collectors.toList()));// 收集为不可修改列表List immutableList = users.stream()    .collect(Collectors.collectingAndThen(        Collectors.toList(),         Collections::unmodifiableList));

基本上就这些常用技巧。合理使用 Collectors 可以让流式处理更加简洁有力,避免手动遍历和条件判断。关键是理解“下游收集器”的组合思想,灵活搭配使用。不复杂但容易忽略的是,很多方法都支持第二参数作为下游收集器,这是实现复杂逻辑的关键。

以上就是在Java中如何使用Collectors收集流结果_Collectors类使用技巧的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/978122.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月1日 20:20:11
下一篇 2025年12月1日 20:20:32

相关推荐

发表回复

登录后才能评论
关注微信