Java 8的Stream API支持函数式编程,可简化集合处理。通过stream()创建流,使用filter、map、sorted实现过滤、转换和排序,结合Collectors将结果收集为List、Set、Map等。例如筛选成年用户姓名:adultNames = users.stream().filter(u -> u.getAge() > 18).map(User::getName).collect(Collectors.toList())。Collectors提供toSet()去重、joining()拼接字符串、averagingInt()求平均值等功能。groupingBy()按属性分组,返回Map<K, List<V>>,支持多级嵌套;partitioningBy()按布尔条件分为两组。中间操作惰性执行,仅在终止操作时触发。避免在流中执行复杂逻辑或IO操作,大数据量可考虑parallelStream但需注意线程安全。普通集合流无需关闭。合理使用Stream + Collectors可提升代码简洁性与可读性,适用于数据筛选、转换与统计场景。

Java 8引入的Stream API为集合数据的处理带来了函数式编程的便利。通过Stream,开发者可以更简洁、清晰地完成过滤、映射、排序、归约等操作。结合Collectors工具类,还能方便地将流结果收集为List、Set、Map或进行分组、分区等复杂操作。
可以从集合、数组或静态方法创建Stream。常见的操作包括filter、map、sorted等。
例如,从一个用户列表中筛选出年龄大于18的用户,并提取其姓名:
List<User> users = Arrays.asList(
new User("张三", 20),
new User("李四", 17),
new User("王五", 25)
);
List<String> adultNames = users.stream()
.filter(user -> user.getAge() > 18)
.map(User::getName)
.collect(Collectors.toList());
说明:stream()启动流,filter按条件过滤,map转换元素,collect将结果收集为List。
立即学习“Java免费学习笔记(深入)”;
Collectors提供了多种数据聚合方式,适用于不同业务场景。
String names = users.stream()
.map(User::getName)
.collect(Collectors.joining(", "));
Double avgAge = users.stream()
.collect(Collectors.averagingInt(User::getAge));
Collectors.groupingBy用于按某个属性分组,返回Map结构。
Map<Integer, List<User>> groupedByAge = users.stream()
.collect(Collectors.groupingBy(User::getAge));
Map<Boolean, List<User>> partitionedByAdult = users.stream()
.collect(Collectors.partitioningBy(u -> u.getAge() >= 18));
groupingBy支持多级分组,可嵌套使用;partitioningBy基于布尔条件分为两组。
Stream虽简洁,但需注意性能和使用方式。
基本上就这些。合理使用Stream + Collectors能让代码更简洁、意图更明确,尤其适合数据转换和统计场景。
以上就是在Java中如何使用Stream和Collectors处理集合数据_Stream流操作指南的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号