Java Stream API 提供声明式处理集合数据的方式,通过中间操作和终端操作实现链式调用。首先需从集合、数组或静态方法获取流,如 list.stream()、Arrays.stream(array) 或 Stream.of()。中间操作包括 filter 过滤、map 转换、flatMap 扁平化、sorted 排序、distinct 去重、limit/skip 截取等,均返回新流且延迟执行。终端操作触发实际计算,如 forEach 遍历、collect 收集结果、reduce 聚合、count 计数、match 匹配判断、find 查找元素。示例中筛选年龄大于18的用户,提取姓名并转大写后收集为列表,体现代码简洁性。Stream 支持串行与并行处理(parallelStream),提升性能,但流只能使用一次,不可重复消费。

Java Stream API 提供了一种声明式、函数式的方式处理集合数据,让代码更简洁、易读。它不直接修改原始集合,而是通过中间操作和终端操作对数据进行流水线处理。
创建 Stream 流
要使用 Stream API,首先需要从集合或其他数据源获取流:
- List 转 Stream: list.stream()
- 数组转 Stream: Arrays.stream(array)
- 静态生成: Stream.of(1, 2, 3) 或 Stream.iterate()、Stream.generate()
常用中间操作(返回 Stream)
中间操作可以链式调用,它们不会立即执行,而是延迟加载,直到终端操作触发:
- filter(Predicate): 过滤元素,例如只保留偶数或非空字符串
- map(Function): 转换元素类型,比如将字符串转为大写,或对象提取某个字段
- flatMap(Function): 将每个元素展开成多个元素,常用于合并嵌套集合
- sorted(): 对流中元素排序,可自定义比较器
- distinct(): 去重,基于元素的 equals 方法
- limit(n) / skip(n): 截取前 n 个元素或跳过前 n 个
常用终端操作(触发执行并产生结果)
终端操作会结束流,执行所有中间操作并返回结果:
JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合于服务器与 JavaScript 的交互。本文将快速讲解 JSON 格式,并通过代码示例演示如何分别在客户端和服务器端进行 JSON 格式数据的处理。
立即学习“Java免费学习笔记(深入)”;
- forEach(Consumer): 遍历每个元素,常用于打印或处理
- collect(Collector): 将流转换为集合、字符串等,如 toList()、toSet()、joining()
- reduce(BinaryOperator): 聚合操作,比如求和、拼接
- count(): 返回元素数量
- anyMatch / allMatch / noneMatch: 判断是否有元素满足条件
- findFirst / findAny: 获取第一个或任意一个元素(适合并行流)
实际示例
假设有一个用户列表,想筛选年龄大于18的用户,提取姓名并转为大写,最后收集为新列表:
List.filter(u -> u.getAge() > 18)
.map(User::getName)
.map(String::toUpperCase)
.collect(Collectors.toList());
基本上就这些。Stream API 让集合处理更直观,避免了传统 for 循环中的冗余代码,同时支持串行和并行处理(parallelStream),提升大数据量下的性能表现。不过注意:流只能消费一次,不能重复使用。









