JDK8新特性--Stream流

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)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值