首页 > 其他分享 >流式思想概述和两种获取Stream流的方式

流式思想概述和两种获取Stream流的方式

时间:2022-09-23 11:23:15浏览次数:49  
标签:Stream 元素 流式 获取 概述 集合 操作

流式思想概述

整体来看,流式思想类似于工厂车间的“生产流水线”。

 

当需要对多个元素进行操作(特别是多步操作)的时候,考虑到性能及便利性,我们应该首先拼好一个“模型”步骤 方案,然后再按照方案去执行它

这张图中展示了过滤、映射、跳过、计数等多步操作,这是一种集合元素的处理方案,而方案就是一种“函数模 型”。图中的每一个方框都是一个“流”,调用指定的方法,可以从一个流模型转换为另一个流模型。而最右侧的数字 3是最终结果。

这里的 filter 、 map 、 skip 都是在对函数模型进行操作,集合元素并没有真正被处理。只有当终结方法 count 执行的时候,整个模型才会按照指定策略执行操作。而这得益于Lambda的延迟执行特性。

备注:“Stream流”其实是一个集合元素的函数模型,它并不是集合,也不是数据结构,其本身并不存储任何 元素(或其地址值)。

Stream(流)是一个来自数据源的元素队列

  元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。

  数据源 流的来源。 可以是集合,数组 等。

和以前的Collection操作不同, Stream操作还有两个基础的特征:

  Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。

  内部迭代: 以前对集合遍历都是通过Iterator或者增强for的方式, 显式的在集合外部进行迭代, 这叫做外部迭 代。Stream提供了内部迭代的方式,流可以直接调用遍历方法。

当使用一个流的时候,通常包括三个基本步骤:获取一个数据源(source)→ 数据转换→执行操作获取想要的结 果,每次转换原有 Stream 对象不改变,返回一个新的 Stream 对象(可以有多次转换),这就允许对其操作可以 像链条一样排列,变成一个管道

两种获取Stream流的方式

-所有的 Collection 集合都可以通过 stream 默认方法获取流;
  default String<E> stream()
-Stream 接口的静态方法 of 可以获取数组对应的流。
  static<T> Stream<T> of (T...values)
  参数是一个可变参数,那么我们就可以传递一个数组

1.所有的Collecton集合都可以通过stream默认读取流
2.Stream的接口的静态方法of可以获取相对应的流

标签:Stream,元素,流式,获取,概述,集合,操作
From: https://www.cnblogs.com/wsfj/p/16722034.html

相关文章

  • Stream流中的常用方法-forEach和Filter方法
    Stream流中的常用方法-forEach方法流模型的操作很丰富,这里介绍一些常用的APlI。这些方法可以被分成两种︰延迟方法︰返回值类型仍然是Stream接口自身类型的方法,因此支持链......
  • 459测试概述和460junit使用步骤
    测试概述单元测试:1.黑盒测试:不需要写代码,输入值,看程序是否能够输出期望值2.白盒测试:需要写代码。关注程序具体执行的流程  Junit使用步骤白盒测试步骤:1.定......
  • 448stream流中的常用方法_concai和451方法基本介绍
    组合concat如果有两个流,希望合并成为一个流,那么可以使用Stream接口的静态方法concatstatic<T>Stream<T>concat(Stream<?extendsT>a,Stream<?extendsT>b)备注:这......
  • 444stream流中的常用方法_map和445Stream流中的常用方法_count
    映射Map如果需要将流中的元素映射到另一个另一个流中,可以使用map方法方法签名:<R>Stream<R>map(Function<?superT,?extendsR>mapper);该接口需要一个Function......
  • 441stream流中的常用方法_forEach和442Stream流中的常用方法_filter
    常用方法forEach   流模型的操作很丰富,这里介绍一些常用的APl。这些方法可以被分成两种:延迟方法︰返回值类型仍然是Stream接口自身类型的方法,因此支持链式调用。(除......
  • java stream(jrebel.com)
    pdf版https://www.jrebel.com/system/files/java-8-streams-cheat-sheet.pdf ......
  • OpenTelemetry概述
    1前世如果你常年在处理一些日志、监控方面的东西,一定会在一定程度上听过OpenTracing,像Zipkin、Jaeger、SkyWalking都对其有很好的支持。但是可惜,OpenTracing已经成为过去......
  • 反射-Class对象功能概述和获取Field
    反射-Class对象功能 publicstaticvoidmain(String[]args)throwsException{//获取Person的Class对象ClasspersonClass=Person.class;......
  • Dubbo概述
    什么是RPCRPC是RemoteProcedureCall的缩写 翻译为:远程过程调用目标是为了实现两台(多台)计算机\服务器,相互调用方法\通信的解决方案RPC只是实现远程调用的一套标准......
  • 方法引用-数组的构造器引用和Junit测试概述
    方法引用-数组的构造器引用ArrayBuilder接口/*定义一个创建数组的函数式接口*/publicinterfaceArrayBuilder{//定义一个创建int类型数组的方法,参数传递......