JAVA8 Stream API介绍

本文介绍了Java8引入的StreamAPI,一种声明性数据处理工具,支持中间操作如过滤、映射和排序,以及终端操作如收集、forEach和reduce。文章还讨论了并行流的使用和注意事项。
摘要由CSDN通过智能技术生成

Java 8 引入的 Stream API 是一种高级迭代器,它允许你以声明性方式处理数据集合(包括数组、集合等)。Stream API 可以看作是值的序列,它支持许多不同种类的操作来执行数据的聚合、过滤、映射等操作。这些操作可以是顺序的,也可以是并行的。

Stream 操作分为两种基本类型:中间操作和终端操作。

  • 中间操作(Intermediate operations):返回 Stream 自身的操作。因为它们返回的是 Stream,所以可以链式调用多个中间操作,而不会执行任何实际计算,这被称为惰性求值。
  • 终端操作(Terminal operations):返回一个结果或副作用,执行实际的计算,并且之后不能再使用 Stream。

Stream API 操作示例

下面通过一系列示例来展示 Stream API 的基本使用:

1. 创建 Stream
Stream<String> stream = Stream.of("a", "b", "c");
List<String> list = Arrays.asList("a", "b", "c");
Stream<String> streamFromList = list.stream();
2. 中间操作
  • filter:过滤 Stream 中的元素。

    list.stream().filter(e -> e.contains("b")).forEach(System.out::println); // 输出 "b"
    
  • map:将 Stream 中的每个元素映射到另一个元素。

    list.stream().map(String::toUpperCase).forEach(System.out::println); // 输出 "A", "B", "C"
    
  • sorted:对 Stream 中的元素进行排序。

    list.stream().sorted().forEach(System.out::println); // 根据元素的自然顺序排序
    
3. 终端操作
  • collect:将 Stream 的结果收集到不同类型的结果中,比如一个 List 或者一个 Set。

    List<String> filtered = list.stream().filter(e -> e.contains("b")).collect(Collectors.toList());
    
  • forEach:对 Stream 中的每个元素执行操作。

    list.stream().forEach(System.out::println); // 输出 "a", "b", "c"
    
  • reduce:将 Stream 中的元素组合起来,使用给定的组合函数。

    Optional<String> combined = list.stream().reduce((s1, s2) -> s1 + "," + s2);
    combined.ifPresent(System.out::println); // 输出 "a,b,c"
    
4. 并行 Streams

Stream API 并行操作允许你以并行方式处理元素,这可以显著提高大数据集的处理性能。

List<String> parallelResult = list.parallelStream()
        .filter(e -> e.contains("b"))
        .collect(Collectors.toList());

注意事项

  • Stream 一旦被消费(一个终端操作被执行),就不能再次使用。
  • Stream 操作不会修改其底层的数据结构,它们只会提供一个结果或执行一个指定的操作。
  • 并行 Stream 应谨慎使用,因为并行操作增加了复杂性,并且不是所有情况下都能带来性能上的提升。

结论

Stream API 是处理集合的强大工具,它提供了一种直观而又声明式的方法来处理数据。通过中间操作和终端操作的组合,你可以构建复杂的数据处理管道,而且这些操作可以是顺序的,也可以是并行的。掌握 Stream API 可以大大提高你处理集合数据的能力和效率。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员爱学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值