Stream(流)是一个来自数据源的元素队列 元素是特定类型的对象,形成一个队列。
Java中的Stream并不会存储元素,而是按需计算。
数据源流的来源。 可以是集合,数组 等。
和以前的Collection操作不同, Stream操作还有两个基础的特征:
Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
内部迭代: 以前对集合遍历都是通过Iterator或者增强for的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式,流可以直接调用遍历方法。
获取流
java.util.stream.Stream 是Java 8新加入的最常用的流接口。(这并不是一个函数式接口。)
获取一个流非常简单,有以下几种常用的方式:
所有的 Collection 集合都可以通过 stream 默认方法获取流;
default Stream<E> stream()
Stream 接口的静态方法 of 可以获取数组对应的流。
static <T> Stream<T> of(T... values)
常用方法
逐一处理:forEach 虽然方法名字叫 forEach ,但是与for循环中的“for-each”昵称不同。
void forEach(Consumer<? super T> action);
过滤:filter可以通过 filter 方法将一个流转换成另一个子集流。方法:
Stream<T> filter(Predicate<? super T> predicate);
映射:map如果需要将流中的元素映射到另一个流中,可以使用 map 方法。方法签名:
<R> Stream<R> map(Function<? super T,? extends R> mapper);
统计个数:count 正如旧集合 Collection 当中的 size 方法一样,流提供 count 方法来数一数其中的元素个数:
long count()
取用前几个:limit limit 方法可以对流进行截取,只取用前n个。方法签名:
Stream<T> limit(long maxSize);
跳过前几个:skip 如果希望跳过前几个元素,可以使用 skip 方法获取一个截取之后的新流:
Stream<T> skip(long n);
组合:concat 如果有两个流,希望合并成为一个流,那么可以使用 Stream 接口的静态方法 concat :
static <T> Stream<T> concat(Stream<? extends T> a, Stream<? extends T> b)