什么是stream流,
stream流是java1.8之后开启的,主要是为了解放程序员操作集合时的生产力,主要是lambda表达式提供了很大的帮助。
它可以实现对集合(是一种静态结构,存储在内存当中,而stream是通过cpu来实现计算的(并不会存储结构))的复杂操作,过滤、排序、映射等。
我们可以将stream理解为管道,管道里面的操作主要是对流进行过滤、分组、收集、归约这类操作,最后有一个终止管道装有最终结果。
stream流也好像是一个高级的迭代器,但是每次只能遍历一次,就有点像江水,我们只能对流进行过滤、筛选等一些操作,最终还是需要使用终端操作将最终结果进行反馈。
操作流
中间操作:可以有多个、每次返回一个新的流,可以进行链式操作。
终端操作:每次流只能使用一个,每次执行完成之后,这个流也就用光了,无法执行下一个操作,因此只能放在最后。
stream流的特性
1、不存储数据,而是按照特定的规则对数据进行计数。
2、不改变数据源,通常情况下会产生一个新的集合。
3、stream具有延迟执行的特性,只有调用终端操作时,中间操作才会执行
4、stream流不可复用,对一个已经进行过终端操作的流再次调用,会抛出异常。
延迟执行
stream在没有遇到终端操作之前,不会执行流中的任何一个中间操作,不会对流进行处理;(题外话,感觉像是stream中的终端操作中有一个启动流的操作,有点感觉像是类似于线程中的start这个方法)
创建流的方式三种
/**
* 1.通过集合创建流
*/

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

被折叠的 条评论
为什么被折叠?



