Stream

A sequence of elements supporting sequential and parallel aggregate operations Stream是一组用来处理数组、集合的API

▪ Java 8之所以费这么大功夫引入函数式编程,原因有二:

– 代码简洁函数式编程写出的代码简洁且意图明确,使用stream接口让你从 此告别for循环。

– 多核友好,Java函数式编程使得编写并行程序从未如此简单,你需要的全部 就是调用一下parallel()方法

Stream 的操作三个步骤
1> 创建 Stream : 一个数据源 (如 : 集合、数组), 获取一个流
2> 中间操作 : 一个中间操作链,对数据源的数据进行处理
3> 终止操作(终端操作) : 一个终止操作,执行中间操作链,并产生结果

Stream特性

1:不是数据结构,没有内部存储

2:不支持索引访问

3:延迟计算

4:支持并行

5:很容易生成数组或集合(List,Set)

6:支持过滤,查找,转换,汇总,聚合等操作

Stream运行机制

Stream分为 源source,中间操作,终止操作

流的源可以是一个数组、一个集合、一个生成器方法,一个I/O通 道等等。

一个流可以有零个和或者多个中间操作,每一个中间操作都会返回 一个新的流,供下一个操作使用。

一个流只会有一个终止操作 Stream只有遇到终止操作,它的源才开始执行遍历操作

Stream的创建

1、通过数组

2、通过集合来

3、通过Stream.generate方法来创建

4、通过Stream.iterate方法来创建

5、其他API创建

// Java8 中的Collection接口被扩展,提供了两个获取流的方法:
default Stream<E> stream() // 返回一个顺序流
default Stream<E> parallelStream() // 返回一个并行流
 
// -- 由数组创建流
// Java8 中的Arrays 的静态方法stream() 可以获取数组流:
static <T> Stream<T> stream(T[] array) // 返回一个流
 
// 重载形式,能够处理对应基本类型的数组:
public static IntStream stream(int[] array)
public static LongStream stream(long[] array)
public static DoubleStream stream(double[] array)
 
// -- 由值创建流
// 可以使用静态方法Stream.of(),通过显示值创建一个流。它可以接收任意数量的参数。
public static<T> Stream<T> of(T… values) // 返回一个流
 
// -- 由函数创建流:创建无限流
// 可以使用静态方法Stream.iterate() 和Stream.generate(),创建无限流。
// 迭代
Public static<T> Stream<T> iterate(final T seed, final UnaryOperator<T> f)
// 生成
Public static<T> Stream<T> generate(Supplier<T> s)

Stream的生成方式

1)从Collection和数组获得

  • Collection.stream()
  • Collection.parallelStream()  (并行执行的流.它通过默认的ForkJoinPool,可能提高多线程任务的速度)
  • Arrays.stream(T array) or Stream.of()

(2)从BufferedReader获得

  • java.io.BufferedReader.lines()

(3)静态工厂

  • java.util.stream.IntStream.range()
  • java.nio.file.Files.walk()

(4)自己构建

  • java.util.Spliterator

(5)其他

  • Random.ints()
  • BitSet.stream()
  • Pattern.splitAsStream(java.lang.CharSequence)
  • JarFile.stream()

Stream常用API 中间操作 过滤 filter 去重 distinct 排序 sorted 截取 limit、skip 转换 map/flatMap 其他 peek

Stream常用API 终止操作 循环 forEach 计算 min、max、count、 average 匹配 anyMatch、 allMatch、 noneMatch、 findFirst、 findAny 汇聚 reduce 收集器 toArray collect

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐