Java中的Stream API:从入门到实战

引言

在现代Java开发中,Stream API 是处理集合数据的强大工具。它不仅让代码更加简洁易读,还能通过并行处理提升性能。本文将带你从基础概念入手,逐步深入Stream API的使用,并通过实战案例展示其强大功能。

1. 什么是Stream API?

Stream API 是Java 8引入的一个新特性,用于处理集合数据。它允许你以声明式的方式对数据进行操作,比如过滤、映射、排序等。Stream API的核心思想是将数据操作分为中间操作终端操作

  • 中间操作 :如 filter()map()sorted(),它们返回一个新的Stream,可以链式调用。
  • 终端操作 :如 collect()forEach()reduce(),它们触发Stream的处理并返回结果。

2. Stream API的核心操作

2.1 创建Stream

Stream可以通过多种方式创建:

java 复制代码
// 从集合创建
List<String> list = Arrays.asList("Java", "Python", "C++");
Stream<String> stream = list.stream();

// 从数组创建
Stream<String> arrayStream = Arrays.stream(new String[]{"A", "B", "C"});

// 使用Stream.of()
Stream<Integer> numberStream = Stream.of(1, 2, 3, 4);

2.2 中间操作

  • filter():过滤元素
java 复制代码
List<String> languages = Arrays.asList("Java", "Python", "C++", "JavaScript");
List<String> filtered = languages.stream()
                                 .filter(lang -> lang.startsWith("J"))
                                 .collect(Collectors.toList());
// 结果: ["Java", "JavaScript"]
  • map():转换元素
java 复制代码
List<String> languages = Arrays.asList("Java", "Python", "C++");
List<Integer> lengths = languages.stream()
                                 .map(String::length)
                                 .collect(Collectors.toList());
// 结果: [4, 6, 3]
  • sorted():排序
java 复制代码
List<String> sortedLanguages = languages.stream()
                                        .sorted()
                                        .collect(Collectors.toList());
// 结果: ["C++", "Java", "JavaScript", "Python"]

2.3 终端操作

  • collect():将Stream转换为集合
java 复制代码
List<String> result = stream.collect(Collectors.toList());
  • forEach():遍历元素
java 复制代码
languages.stream().forEach(System.out::println);
  • reduce():归约操作
java 复制代码
Optional<String> combined = languages.stream()
                                     .reduce((s1, s2) -> s1 + ", " + s2);
// 结果: "Java, Python, C++"

3. 并行Stream

Stream API 支持并行处理,只需将 stream() 替换为 parallelStream() 即可:

java 复制代码
List<String> languages = Arrays.asList("Java", "Python", "C++", "JavaScript");
List<String> result = languages.parallelStream()
                               .filter(lang -> lang.length() > 3)
                               .collect(Collectors.toList());

4. 实战案例:统计文本中的单词频率

假设我们有一段文本,需要统计每个单词出现的频率:

java 复制代码
String text = "Java is a programming language Java is widely used";
Map<String, Long> wordCounts = Arrays.stream(text.split(" "))
                                     .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));
// 结果: {Java=2, is=2, a=1, programming=1, language=1, widely=1, used=1}

5. 注意事项

  • Stream是一次性的:一旦被消费,就不能重复使用。
  • 避免副作用:Stream操作应尽量保持无状态,避免修改外部变量。
  • 性能权衡:并行Stream并不总是更快,需根据数据量和操作复杂度评估。

6. 总结

Stream API 是Java中处理集合数据的利器,它让代码更加简洁、易读且高效。通过本文的学习,你应该已经掌握了Stream的基本用法,并能够在实际项目中灵活运用。希望这篇博客对你有所帮助!


推荐阅读文章

相关推荐
雨奔10 小时前
Kubernetes DNS 完全指南:服务发现核心机制与实践
java·kubernetes·服务发现
逻辑驱动的ken10 小时前
Java高频面试考点场景题14
java·开发语言·深度学习·面试·职场和发展·求职招聘·春招
阿冰冰呀10 小时前
互联网大厂Java求职面试实录:谢飞机的“水货”之路
java·mybatis·dubbo·springboot·线程池·多线程·hashmap
茅盾体10 小时前
汽车零件订单自动同步系统方案
python
2401_8836002510 小时前
golang如何理解weak pointer弱引用_golang weak pointer弱引用总结
jvm·数据库·python
水无痕simon10 小时前
1.单机部署Nacos1.3.2
java
FreakStudio10 小时前
和做工厂系统的印尼老哥,复刻了一套属于 MicroPython 的包管理系统
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
2301_7735536210 小时前
mysql如何评估SQL语句的索引开销_mysql性能追踪与分析
jvm·数据库·python
l1t11 小时前
DeepSeek辅助解决windows 11 wsl2中Linux版Dbeaver显示中文
linux·运维·windows
pele11 小时前
PHP源码运行受主板供电影响吗_供电相数重要性说明【技巧】
jvm·数据库·python