stream流

Java 1.8 引入的Stream流提高了集合操作效率,它不存储数据,而是通过CPU进行计算。Stream是延迟执行的,中间操作如过滤、映射等在调用终端操作前不会执行。流只能遍历一次,终端操作如求和、分组后,流不能复用。本文将探讨Stream的创建、中间操作、终端操作及其特性。

什么是stream流,

stream流是java1.8之后开启的,主要是为了解放程序员操作集合时的生产力,主要是lambda表达式提供了很大的帮助。

它可以实现对集合(是一种静态结构,存储在内存当中,而stream是通过cpu来实现计算的(并不会存储结构))的复杂操作,过滤、排序、映射等。

我们可以将stream理解为管道,管道里面的操作主要是对流进行过滤、分组、收集、归约这类操作,最后有一个终止管道装有最终结果。

stream流也好像是一个高级的迭代器,但是每次只能遍历一次,就有点像江水,我们只能对流进行过滤、筛选等一些操作,最终还是需要使用终端操作将最终结果进行反馈。

操作流

中间操作:可以有多个、每次返回一个新的流,可以进行链式操作。
终端操作:每次流只能使用一个,每次执行完成之后,这个流也就用光了,无法执行下一个操作,因此只能放在最后。

stream流的特性

1、不存储数据,而是按照特定的规则对数据进行计数。
2、不改变数据源,通常情况下会产生一个新的集合。
3、stream具有延迟执行的特性,只有调用终端操作时,中间操作才会执行
4、stream流不可复用,对一个已经进行过终端操作的流再次调用,会抛出异常。

延迟执行

stream在没有遇到终端操作之前,不会执行流中的任何一个中间操作,不会对流进行处理;(题外话,感觉像是stream中的终端操作中有一个启动流的操作,有点感觉像是类似于线程中的start这个方法)

创建流的方式三种

/**
	 * 1.通过集合创建流
	 */
	
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值