Java里如何使用Stream流操作集合_Stream流在集合操作中的应用解析

Java 8的Stream API通过声明式处理集合数据,支持函数式编程,提升代码简洁性与可读性。

java里如何使用stream流操作集合_stream流在集合操作中的应用解析

Java 8 引入的 Stream API 极大地简化了集合数据的操作。它允许开发者以声明式方式处理数据集合,支持函数式编程风格,让代码更简洁、可读性更强。Stream 不是存储数据的结构,也不会修改源数据,而是通过中间操作和终止操作完成对集合元素的流水线处理。

创建 Stream 流

要使用 Stream,首先需要从集合或其他数据源获取流实例:

从集合创建:List、Set 等集合类都提供了 stream() 方法。 List list = Arrays.asList(“a”, “b”, “c”);
Stream stream = list.stream(); 从数组创建:使用 Arrays.stream() 或 Stream.of()。 String[] arr = {“x”, “y”, “z”};
Stream stream = Arrays.stream(arr); 生成无限流:使用 Stream.iterate() 或 Stream.generate()。 Stream infinite = Stream.iterate(0, n -> n + 2);
Stream randoms = Stream.generate(Math::random);

常用中间操作

中间操作返回一个新的 Stream,可以链式调用多个操作,但不会立即执行(惰性求值)。

filter(Predicate):按条件过滤元素。 list.stream().filter(s -> s.length() > 1) map(Function):将每个元素转换成另一种形式。 list.stream().map(String::toUpperCase) flatMap(Function):将流中的每个元素展开为多个元素并合并为一个流。 Stream.of(“hello”, “world”).flatMap(s -> Arrays.stream(s.split(“”))) distinct():去重,基于 equals 方法。 sorted():自然排序或自定义比较器排序。 list.stream().sorted(Comparator.comparing(String::length)) limit(n)skip(n):限制数量或跳过前 n 个元素。

常见终止操作

终止操作触发实际计算,并产生结果或副作用,之后 Stream 不可再用。

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

网易人工智能 网易人工智能

网易数帆多媒体智能生产力平台

网易人工智能 206 查看详情 网易人工智能 forEach(Consumer):遍历每个元素,常用于打印或处理。 list.stream().forEach(System.out::println); collect(Collector):将流转换为集合、字符串等。 List result = list.stream().map(String::toUpperCase).collect(Collectors.toList());
String joined = list.stream().collect(Collectors.joining(“,”)); count():返回元素数量,返回 long 类型。 anyMatch / allMatch / noneMatch:判断是否有元素匹配、全部匹配或都不匹配。 boolean hasA = list.stream().anyMatch(s -> s.equals(“a”)); findAny / findFirst:返回任意或第一个元素,通常配合 filter 使用。 Optional found = list.stream().filter(s -> s.startsWith(“b”)).findAny();

实际应用场景示例

假设有一个用户列表,我们需要筛选年龄大于 18 的用户,提取姓名并去重排序:

List users = Arrays.asList(
  new User(“Alice”, 25),
  new User(“Bob”, 17),
  new User(“Charlie”, 30),
  new User(“Alice”, 22)
);

List adultNames = users.stream()
  .filter(u -> u.getAge() >= 18)
  .map(User::getName)
  .distinct()
  .sorted()
  .collect(Collectors.toList());

这段代码逻辑清晰,避免了传统 for 循环嵌套判断和手动去重的过程。

基本上就这些。Stream 让集合操作变得更直观,合理使用能显著提升开发效率和代码质量。注意避免在多线程环境下共享可变状态,同时慎用 parallelStream 防止意外副作用。

以上就是Java里如何使用Stream流操作集合_Stream流在集合操作中的应用解析的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 18:10:02
下一篇 2025年12月2日 18:10:23

相关推荐

发表回复

登录后才能评论
关注微信