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. python爬虫入门(五)Selenium模拟用户操作

    爬虫(Spider),反爬虫(Anti-Spider),反反爬虫(Anti-Anti-Spider) 之间恢宏壮阔的斗争... 小莫想要某站上所有的电影,写了标准的爬虫(基于HttpClient库), ...

  2. Runc 简介

    RunC 是什么? RunC 是一个轻量级的工具,它是用来运行容器的,只用来做这一件事,并且这一件事要做好.我们可以认为它就是个命令行小工具,可以不用通过 docker 引擎,直接运行容器.事实上,r ...

  3. python 闯关之路三(面向对象与网络编程)

    1,简述socket 通信原理 如上图,socket通信建立在应用层与TCP/IP协议组通信(运输层)的中间软件抽象层,它是一组接口,在设计模式中,socket其实就是一个门面模式,它把复杂的TCP/ ...

  4. 【转】tomcat logs 目录下各日志文件的含义

    tomcat每次启动时,自动在logs目录下生产以下日志文件,按照日期自动备份   localhost.2016-07-05.txt   //经常用到的文件之一 ,程序异常没有被捕获的时候抛出的地方 ...

  5. Windows上使用Git托管代码到Coding

    作者:荒原之梦 Git简介: Git是一款分布式版本控制系统,可用于项目的版本管理.Git可以管理本地代码仓库与远程代码仓库间的连接以及进行版本控制,使得我们可以在本地离线进行修改等操作,之后再将代码 ...

  6. Spring Security 源码分析(四):Spring Social实现微信社交登录

    社交登录又称作社会化登录(Social Login),是指网站的用户可以使用腾讯QQ.人人网.开心网.新浪微博.搜狐微博.腾讯微博.淘宝.豆瓣.MSN.Google等社会化媒体账号登录该网站. 前言 ...

  7. HTML5 CSS3专题 纯CSS打造相册效果

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/30993277 今天偶然发现电脑里面还有这样的一个例子,感觉效果还不错,不记得啥时 ...

  8. Android 自定义ViewGroup手把手教你实现ArcMenu

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/37567907 逛eoe发现这样的UI效果,感觉很不错,后来知道github上有这 ...

  9. SpringBoot JMS(ActiveMQ) 使用实践

    ActiveMQ 1. 下载windows办的activeMQ后,在以下目录可以启动: 2. 启动后会有以下提示 3. 所以我们可以通过http://localhost:8161访问管理页面,通过tc ...

  10. stats.go

    , len(c.clients))             for _, client := range c.clients {                 clients = append(cl ...