Java 8 引入了一个强大且灵活的新特性——Stream API。这个 API 的目的是为了简化集合数据的操作和处理,提供一种声明式的方式来进行数据处理,让代码更简洁、更易读。本文将详细介绍 Java 8 Stream API 的核心概念、常见操作和使用示例,帮助开发者更好地理解和使用这一强大的工具。
1. 什么是 Stream?
在 Java 8 中,Stream 是一个从支持数据处理操作的源生成的元素序列。源可以是集合、数组或输入输出资源。Stream API 不会改变源的数据结构,而是返回一个新的 Stream。Stream 的主要特点包括:
- 非存储:Stream 不会存储数据,数据存储在集合、数组等支持的数据源中。
- 函数式:Stream 支持使用函数式编程风格来对数据进行操作。
- 惰性求值:Stream 操作是惰性执行的,只有在需要结果的时候才会执行。
- 可消费:Stream 只能消费一次,一旦被消费就不能再次使用。
2. 创建 Stream
Stream 可以通过多种方式创建,最常见的方式是从集合、数组或静态工厂方法生成。以下是一些常见的创建方式:
// 从集合创建 Stream
List<String> list = Arrays.asList("a", "b", "c");
Stream<String> streamFromList = list.stream();
// 从数组创建 Stream
String[] array = {
"a", "b", "c"};
Stream<String> streamFromArray = Arrays.stream(array);
// 使用 Stream.of() 创建 Stream
Stream<String> streamOf = Stream.of("a", "b", "c");
3. Stream 的操作
Stream 的操作可以分为两类:中间操作和终端操作。
-
中间操作:返回一个新的 Stream,允许方法链式调用。常见的中间操作有
filter()
,map()
,flatMap()
,distinct()
,sorted()
,limit()
,skip()
等。 -
终端操作:触发 Stream 的计算并返回一个结果。常见的终端操作有
forEach()
,collect()
,reduce()
,count()
,anyMatch()
,allMatch()
,noneMatch()
等。
中间操作示例
List<String