玩转Java8 Stream,代码效率飞升

本文详细介绍了Java 8的Stream API,包括其特性、分类和常用操作。Stream API提供了高效处理集合数据的方式,支持顺序和并行操作,通过中间操作(如filter、map、sorted)和终止操作(如match、reduce、collect)实现复杂的数据处理。文章还展示了如何创建Stream,以及如何进行聚合和收集操作,是理解Java 8 Stream API的全面指南。
摘要由CSDN通过智能技术生成

概述

Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。

使用 Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数据库查询。也可以使用 Stream API 来并行执行操作。

简而言之,Stream API 提供了一种高效且易于使用的处理数据的方式。

特点如下:

  1. 不是数据结构,不会保存数据。
  2. 不会修改原来的数据源,它会将操作后的数据保存到另外一个对象中。(保留意见:毕竟 peek 方法可以修改流中元素)
  3. 惰性求值,流在中间处理过程中,只是对操作进行了记录,并不会立即执行,需要等到执行终止操作的时候才会进行实际的计算。

分类

如上图:

  • 无状态:指元素的处理不受之前元素的影响
  • 有状态:指该操作只有拿到所有元素之后才能继续下去
  • 非短路操作:指必须处理所有元素才能得到最终结果
  • 短路操作:指遇到某些符合条件的元素就可以得到最终结果,如 A || B,只要 A 为 true,则无需判断 B 的结果

具体用法

| 流的常用创建方法

使用 Collection 下的 stream() 和 parallelStream() 方法:

List<String> list = new ArrayList<>();
Stream<String> stream = list.stream(); //获取一个顺序流
Stream<String> parallelStream = list.parallelStream(); //获取一个并行流

使用 Arrays 中的 stream() 方法,将数组转成流:

Integer[] nums = new Integer[10];
Stream<Integer> stream = Arrays.stream(nums);
 

使用Stream中的静态方法:of()、iterate()、generate()

Stream<Integer> stream = Stream.of(1,2,3,4,5,6);

Stream<Integer> stream2 = Stream.iterate(0, (x) -> x + 2).limit(6);
stream2.forEach(System.out::println); // 0 2 4 6 8 10

Stream<Double> stream3 = Stream.generate(Math::random).limit(2);
stream3.forEach(System.out::println);

使用 BufferedReader.lines() 方法,将每行内容转成流:

BufferedReader reader = new BufferedReader(new FileReader("F:\\test_stream.txt"));
Stream<String> lineStream = reader.lines();
lineStream.forEach(System.out::println);

使用 Pattern.splitAsStream() 方法,将字符串分隔成流:

Pattern pattern = Pattern.compile(",");
Stream<String> stringStream = pattern.splitAsStream("a,b,c,d");
stringStream.forEach(System.out::println);

| 流的中间操作

筛选与切片:

  • filter:过滤流中的某些元素
  • limit(n):获取 n 个元素
  • skip(n):跳过 n 元素,配合 limit(n) 可实现分页
  • distinct:通过流
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值