Java Stream API 中常用的流处理方法及示例,帮助你高效处理集合数据

Java Stream API 中常用的流处理方法及示例,帮助你高效处理集合数据:

一、中间操作(Intermediate Operations)

中间操作会返回一个新的流,可链式调用多个操作。

1. 过滤(Filter)

筛选符合条件的元素:

java 复制代码
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> evenNumbers = numbers.stream()
    .filter(n -> n % 2 == 0)
    .collect(Collectors.toList()); // [2, 4]
2. 映射(Map)

将元素转换为新形式:

java 复制代码
List<String> names = Arrays.asList("Alice", "Bob");
List<Integer> lengths = names.stream()
    .map(String::length)
    .collect(Collectors.toList()); // [5, 3]
3. 去重(Distinct)

移除重复元素:

java 复制代码
List<Integer> duplicates = Arrays.asList(1, 2, 2, 3);
List<Integer> unique = duplicates.stream()
    .distinct()
    .collect(Collectors.toList()); // [1, 2, 3]
4. 排序(Sorted)

对元素排序:

java 复制代码
List<String> unsorted = Arrays.asList("Z", "A", "M");
List<String> sorted = unsorted.stream()
    .sorted()
    .collect(Collectors.toList()); // [A, M, Z]
5. 切片(Limit/Skip)

限制/跳过元素数量:

java 复制代码
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
// 取前2个元素:[1, 2]
List<Integer> limited = numbers.stream().limit(2).collect(Collectors.toList());
// 跳过前2个元素:[3, 4, 5]
List<Integer> skipped = numbers.stream().skip(2).collect(Collectors.toList());
6. 扁平化(FlatMap)

将嵌套流合并为单一流:

java 复制代码
List<List<Integer>> nested = Arrays.asList(Arrays.asList(1, 2), Arrays.asList(3, 4));
List<Integer> flattened = nested.stream()
    .flatMap(Collection::stream)
    .collect(Collectors.toList()); // [1, 2, 3, 4]
7. ** peek(调试用)**

在流处理过程中打印元素(不改变元素):

java 复制代码
numbers.stream()
    .peek(System.out::println) // 打印每个元素
    .filter(n -> n > 2)
    .collect(Collectors.toList());

二、终端操作(Terminal Operations)

终端操作会终止流并返回结果。

1. 遍历(forEach)

对每个元素执行操作:

java 复制代码
numbers.stream()
    .forEach(n -> System.out.print(n + " ")); // 输出:1 2 3 4 5
2. 收集(Collect)

将流转换为集合或其他结构:

java 复制代码
// 转为 List
List<String> list = names.stream().collect(Collectors.toList());
// 转为 Set
Set<Integer> set = numbers.stream().collect(Collectors.toSet());
// 转为 Map(键需唯一)
Map<String, Integer> map = names.stream()
    .collect(Collectors.toMap(name -> name, String::length));
3. 归约(Reduce)

将元素组合为一个值:

java 复制代码
int sum = numbers.stream()
    .reduce(0, Integer::sum); // 0 + 1 + 2 + 3 + 4 + 5 = 15
4. 统计(Count、Max、Min)
java 复制代码
long count = numbers.stream().count(); // 元素个数
Optional<Integer> max = numbers.stream().max(Integer::compareTo); // 最大值
Optional<Integer> min = numbers.stream().min(Integer::compareTo); // 最小值
5. 分组(GroupingBy)

按属性分组:

java 复制代码
Map<Integer, List<String>> groupByLength = names.stream()
    .collect(Collectors.groupingBy(String::length));
// 输出:{5=[Alice], 3=[Bob]}
6. 分区(PartitioningBy)

按布尔条件分区:

java 复制代码
Map<Boolean, List<Integer>> evenOdd = numbers.stream()
    .collect(Collectors.partitioningBy(n -> n % 2 == 0));
// 输出:{true=[2,4], false=[1,3,5]}

三、其他常用方法

1. 匹配(AnyMatch、AllMatch、NoneMatch)
java 复制代码
boolean hasEven = numbers.stream().anyMatch(n -> n % 2 == 0); // 是否存在偶数
boolean allPositive = numbers.stream().allMatch(n -> n > 0); // 是否全为正数
boolean noneZero = numbers.stream().noneMatch(n -> n == 0); // 是否无零
2. 查找(FindFirst、FindAny)
java 复制代码
Optional<Integer> first = numbers.stream().findFirst(); // 第一个元素(1)
Optional<Integer> any = numbers.stream().findAny(); // 任意元素(并行流中可能不同)

四、示例:链式操作

java 复制代码
List<String> names = Arrays.asList("Apple", "Banana", "Cherry", "Date");

// 需求:过滤出长度>5的单词,转为大写,排序后转为逗号分隔字符串
String result = names.stream()
    .filter(name -> name.length() > 5) // ["Banana", "Cherry"]
    .map(String::toUpperCase) // ["BANANA", "CHERRY"]
    .sorted() // ["BANANA", "CHERRY"]
    .collect(Collectors.joining(", ")); // "BANANA, CHERRY"

五、注意事项

  1. 惰性求值:中间操作只有在终端操作触发时才会执行。
  2. 不可变性:流不会修改原始数据。
  3. 并行流 :通过 stream().parallel() 可启用并行处理,但需注意线程安全。

根据具体需求选择合适的方法组合,可显著简化集合处理逻辑。

相关推荐
蓝澈11211 分钟前
弗洛伊德(Floyd)算法-各个顶点之间的最短路径问题
java·数据结构·动态规划
再见晴天*_*9 分钟前
logback 日志不打印
java·服务器·logback
幽络源小助理18 分钟前
SpringBoot基于JavaWeb的城乡居民基本医疗信息管理系统
java·spring boot·学习
欧阳有财21 分钟前
[java八股文][Mysql面试篇]日志
java·mysql·面试
TDengine (老段)29 分钟前
使用 StatsD 向 TDengine 写入
java·大数据·数据库·时序数据库·iot·tdengine·涛思数据
真实的菜32 分钟前
JVM类加载系统详解:深入理解Java类的生命周期
java·开发语言·jvm
N_NAN_N1 小时前
类图+案例+代码详解:软件设计模式----原型模式
java·设计模式·原型模式
佛祖保佑永不宕机1 小时前
maven引入本地jar包
java·maven·jar
默默coding的程序猿1 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
在未来等你2 小时前
JVM调优实战 Day 15:云原生环境下的JVM配置
java·jvm·性能优化·虚拟机·调优