Stream流的个人理解

  整体来看,流式思想类似于工厂车间的“生产流水线”,通过一些列操作来获取我们需要的产品

  在Java 8中,得益于Lambda所带来的函数式编程,引入了一个全新的Stream概念,用于解决已有集合类库既有的弊端。

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

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

一.Stream流_Stream流进行集合过滤的效果演示

    1).什么是Stream它在Java中是一个接口它类似于迭代器Stream比迭代器的功能更强大。

                 它也是用来处理集合中的元素,但比迭代器的功能更多。

    2).Stream流可以对集合元素进行连续的筛选、过滤、统计等操作。它再结合Lambda表达式的使用,

         使得这些操作变得非常的简单。

   3).示例代码:

public class Demo {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("张无忌");
list.add("周芷若");
list.add("赵敏");
list.add("张强");
list.add("张三丰"); //1.筛选出所有的张姓学员,并存储到一个新集合
List<String> list1 = new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
if (list.get(i).startsWith("张")) {
list1.add(list.get(i));
}
}
//2.再筛选出张姓学员中名字是3个字的学员,并存储到一个新集合
List<String> list2 = new ArrayList<>();
for (int i = 0; i < list1.size(); i++) {
if (list1.get(i).length() == 3) {
list2.add(list1.get(i));
}
} //3.打印名字是3个字的学员中的第一名学员:
System.out.println(list2.get(0)); System.out.println("----------------------------------"); //使用Stream流结合Lambda表达式
list.stream().filter(s -> s.startsWith("张"))
.filter(s -> s.length() == 3)
.limit(1)
.forEach(System.out::println);
}
}

二.Stream流思想概述

1.流思想:类似于迭代器,用于对”集合元素”和数组进行筛选,过滤,统计用的

2.流的工作方式:流对象的每一个操作都会使这个对象成为垃圾;但这个操作的方法通常会返回一个新流对象

每个流对象都是一次性的,类似于流水线

三. Stream流_获取List_Set_Map_数组流

1.通过Collection集合(List,Set)获取流

List:

List list=new ArrayList();

list.stream();

Set:

Set set=new HashSet();

set.stream();

2.通过Map集合获取流(Map集合不能直接获取流,只能先转成Set再获取)

方式一:

Map map=new HashMap();

Set<Map.Entry> set=map.entrySet();

set.stream();

方式二:

Map map=new HashMap();

Set set=map.values();

set.stream();

Set set1=map.keySet();

set1.stream();

3.通过数组获取流:

A).通过引用类型数组获取流:

Integer[] arr1 = {1,2,3,4};

String[] arr2 = {"a","b","c"};

//1.获取Integer[]数组的流

Stream<Integer> integerStream = Stream.of(arr1);

//2.获取String[]数组的流

Stream<String> stringStream = Stream.of(arr2);

B).通过基本类型数组获取流:

int[] arr = {1,2,3,4};

IntStream s1 = IntStream.of(arr);

四. Stream流_常用方法_逐一处理forEach

1.伪代码

        class Stream流的子类<T>{

            //所有元素

            public void forEach(Consumer<T> c){

                //1.遍历每个元素

                for(T t : 所有元素){

                    //3.将每个元素放到Consumeraccept()方法过一下

                    c.accept(t);

                }

            }

        }

2.只需要重写Consumer接口中的accept方法即可,并传入forEach,forEach参数可以是匿名内部类,lambda或者方法引用

五. Stream流_常用方法_过滤filter

Stream<T>

filter(Predicate<? super T> predicate)

针对相应条件对流中数据进行过滤,过滤的代码只要重写Predicate接口中test方法即可,test方法返回值为boolean类型,对于返回false的元素过滤出去

六. Stream流_常用方法_统计个数count

针对流的操作,统计流中元素的个数并返回long类型值,调用count方法不需要传入参数

七. Stream流_常用方法_取用前几个limit

取流中前几个元素,limit方法参数为int类型,代表元素个数, 重新返回一个新流

八. Stream流_常用方法_跳过前几个skip

取流中第n个元素以及之后的数据,limit方法参数为int类型,代表跳过元素个数,重新返回一个新流

九. Stream流_常用方法_映射(转换)map

<R> Stream<R>

map(Function<? super T,? extends R> mapper)

调用map方法需要传入函数接口Function或者其子类

定义Function时一般会指定两个泛型,前一个泛型为流中元素类型,后一个泛型代表转换后的元素类型

进行类型转换,传入一个类型,返回另一个类型,

十. Stream流_常用方法_合并concat

concat方法用于将两个流合并成一个流,Stream中的静态方法,调用需要传入两个流参数,返回一个新流

十一. Stream流_总结_拼接方法与终结方法

1).拼接方法:这个方法会返回一个Stream流,可以继续对这个流操作。

    2).终结方法:这个方法返回的是最终的值。不是Stream流,不能对流继续操作。

十二. Stream流_常用方法_收集Stream结果collect方法

1).Stream其实是一个集合元素的函数模型它并不是集合也不是数据结构其本身并不存储任何元素或其地址值

    2).有些时候,我们使用Stream过滤元素后,过滤后的元素时存储在一个新流中,我们希望将这些数据存储到一个新的集合中,

       此时,可以将Stream转换为各种集合:

    3).转换为List集合

        Stream<String> stream = ....;

        //转换为List集合

        List<String> list = stream.collect(Collectors.toList());
      
转换为Set集合

        Set<String>
set = stream.collect(Collectors.toSet());

       转换为数组:

        Object[] objArray =
stream.toArray();

java_stream流的更多相关文章

  1. 使用C#处理基于比特流的数据

    使用C#处理基于比特流的数据 0x00 起因 最近需要处理一些基于比特流的数据,计算机处理数据一般都是以byte(8bit)为单位的,使用BinaryReader读取的数据也是如此,即使读取bool型 ...

  2. HTML 事件(三) 事件流与事件委托

    本篇主要介绍HTML DOM中的事件流和事件委托. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4 ...

  3. FILE文件流的中fopen、fread、fseek、fclose的使用

    FILE文件流用于对文件的快速操作,主要的操作函数有fopen.fseek.fread.fclose,在对文件结构比较清楚时使用这几个函数会比较快捷的得到文件中具体位置的数据,提取对我们有用的信息,满 ...

  4. java.IO输入输出流:过滤流:buffer流和data流

    java.io使用了适配器模式装饰模式等设计模式来解决字符流的套接和输入输出问题. 字节流只能一次处理一个字节,为了更方便的操作数据,便加入了套接流. 问题引入:缓冲流为什么比普通的文件字节流效率高? ...

  5. java 字节流与字符流的区别

    字节流与和字符流的使用非常相似,两者除了操作代码上的不同之外,是否还有其他的不同呢?实际上字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的,而字符流在操作时使用了缓冲区,通过缓冲区再操作 ...

  6. BZOJ 3504: [Cqoi2014]危桥 [最大流]

    3504: [Cqoi2014]危桥 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1407  Solved: 703[Submit][Status] ...

  7. java I/O流

    输入流(读取数据的流) BufferedInputStream---继承--->FileInputStream--继承--->InputStream------> (1)字节流操作中 ...

  8. Ford-Fulkerson 最大流算法

    流网络(Flow Networks)指的是一个有向图 G = (V, E),其中每条边 (u, v) ∈ E 均有一非负容量 c(u, v) ≥ 0.如果 (u, v) ∉ E 则可以规定 c(u, ...

  9. .NET基础拾遗(3)字符串、集合和流

    Index: (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开发基础 ...

随机推荐

  1. Robot framework之元素定位实战

    1.1  id 和name 定位 Web页面都是由许多标签和元素组成的,每个标签或元素都是很多属性,好比一个人   id 和name 可以看作一个人的身份证号和姓名.下面看下教育局招生系统的用户名输入 ...

  2. python3+requests:使用类封装接口测试脚本

    前言:接口测试用例较多,我们不可能每个用例都写一次requests,get或者requests,post等,所以对共用方法要进行封装处理 第一次修改:将get请求和post请求单独定义出来,使用过程中 ...

  3. SpringMVC中的文件上传

    1. 配置图片服务器 一般图片会单独保存在图片服务器上, 本文为简化处理, 在Tomcat中配置一个路劲用于专门存放图片 在tomcat上配置图片虚拟目录,在tomcat下conf/server.xm ...

  4. LoadRunner性能测试工具

    1:LoadRunner是一款性能测试软件,通过模拟真实的用户行为,通过负载.并发和性能实时监控以及完成后的测试报告,分析系统可能存在的瓶颈,LoadRunner最为有效的手段之一应该就是并发的控制. ...

  5. SSM-SpringMVC-26:SpringMVC异常骇级之自定义异常注解版

     ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 注解的方法实现异常解析,话不多说,直接搞起,和以前一样的习惯,和上篇博客一样的代码放后面,不一样的在前面 案 ...

  6. Linux kernel的中断子系统之(二):IRQ Domain介绍

    返回目录:<ARM-Linux中断系统>. 总结:一.二概述了软硬件不同角度的IRQ Number和HW Interrupt ID,这就需要他们之间架个桥梁. 三介绍了架设这种桥梁的几种方 ...

  7. Android FoldingLayout 折叠布局 原理及实现(一)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/44278417,本文出自:[张鸿洋的博客] 1.概述 无意中翻到的FoldingL ...

  8. [爬虫]Scrapy 错误ordinal not in range(128)

    报错了: UnicodeDecodeError: 'ascii' codec can't decode byte 0xb0 in position 1: ordinal not in range(12 ...

  9. Flask开发微电影网站(三)

    页面完成后的最终布局 可以看到,页面共同的部分是顶部导航和底部导航 所以我们可以把页面顶部导航和底部导航部分单独定义一个文件home.html,然后让需要使用顶部导航和底部导航的页面都继承home.h ...

  10. rabbitmq 脑裂(网络分区)

    1.产生的原因 https://blog.csdn.net/zyz511919766/article/details/45198055 2.相关配置.如何规避 https://blog.csdn.ne ...