《Java 8 实战》学习笔记系列

定义

流是Java API的新成员,它允许你以声明性方式处理数据集合,可以把它看成遍历数据集的高级迭代器

示例

List<String> threeHighCaloricDishNames =
menu.stream()//从menu获得流
.filter(d -> d.getCalories() > 300)//选出高热量的菜
.map(Dish::getName)//获取菜名
.limit(3)//只选3个菜
.collect(toList());//将结果保存在新的list中返回

组成

1.元素序列

接口,访问特定数据源,如集合

2.源

提供数据,如集合、数组、IO资源

3.数据处理操作

filter、map、reduce、find、match、sort等

特点

1.流水线

很多流操作本身会返回一个流,这样多个操作就可以链接起来,形成一个大的流水线

2.内部迭代

Collection是外部迭代

Stream是内部迭代

3.只能遍历消费一次

和迭代器类似,流只能遍历一次。遍历完之后,我们就说这个流已经被消费掉了。

stream 流操作

数据源

执行查询集合、数组、IO数据

中间操作

形成流水线

1.filter 谓词筛选,返回Stream,操作参数Predicate,T -> boolean

2.map 映射,返回Stream,操作参数Function<T,R>,T -> R

细分

2.1 map + Arrays.stream() 将每个数组分别转化为流

2.2 flatMap + Arrays.stream() 将多个数组分别转化为单个流

2.3 mapToIn,返回IntStream

3.limit 截断流,返回Stream

4.skip 跳过元素

5.sorted 可配合reversed,返回Stream,操作参数Comparator,(T, T) -> int

6.distinct 筛选各异的元素。可替换为在终端操作时,使用toSet()去除重复元素,返回Stream

7.range 范围

8.boxed 包装类

终端操作

生成结果

forEach 消费流中的每个元素并对其应用 Lambda。这一操作返回 void

count 返回流中元素的个数。这一操作返回 long

sum 求和

noneMatch 不匹配

collect 把流归约成一个集合,比如 List、 Map、Set 甚至是 Integer

groupingBy 分组

partitioningBy 分区,谓词返回bool

Collectors.toList() 转换

Collectors.counting() 可直接一起换成count

maxBy 最大值

summingInt 汇总

averagingInt 平均数

summarizingInt 返回一个IntSummaryStatistics对象

包括

count

sum

min

max

average

joining 连接字符串

reducing

查找和匹配

anyMatch 流中是否有一个元素匹配谓词

menu.stream().anyMatch(Dish::isVegetarian)

allMatch 流中是否全部元素匹配谓词

menu.stream().allMatch(d -> d.getCalories() < 1000)

noneMatch 流中是否没有元素匹配谓词

menu.stream().noneMatch(d -> d.getCalories() >= 1000)

findAny 找到结果时短路,立即结束

ifPresent 是否包含,如果包含可以执行代码块内容

findFirst 查找第一个

reduce 归约,例如计算求和累加、累乘、最大最小值等,代替for

并行流

parallel() 顺序流转换为并行流

parallelStream

Java8新特性之流stream的更多相关文章

  1. 功能:Java8新特性steam流

    Java8新特性steam流 一.包装数据类型 @Test public void main22() { List<Integer> list = new ArrayList<Int ...

  2. Java8 新特性之流式数据处理

    一. 流式处理简介 在我接触到java8流式处理的时候,我的第一感觉是流式处理让集合操作变得简洁了许多,通常我们需要多行代码才能完成的操作,借助于流式处理可以在一行中实现.比如我们希望对一个包含整数的 ...

  3. Java8 新特性之流式数据处理(转)

    转自:https://www.cnblogs.com/shenlanzhizun/p/6027042.html 一. 流式处理简介 在我接触到java8流式处理的时候,我的第一感觉是流式处理让集合操作 ...

  4. 零基础学习java------21---------动态代理,java8新特性(lambda, stream,DateApi)

    1. 动态代理 在一个方法前后加内容,最简单直观的方法就是直接在代码上加内容(如数据库中的事务),但这样写不够灵活,并且代码可维护性差,所以就需要引入动态代理 1.1 静态代理实现 在讲动态代理之前, ...

  5. java8新特性学习:stream与lambda

    Streams api 对 Stream 的使用就是实现一个 filter-map-reduce 过程,产生一个最终结果,或者导致一个副作用(side effect). 流的操作类型分为两种: Int ...

  6. java8新特性Lambda和Stream

    Java8出来已经4年,但还是有很多人用上了jdk8,但并没用到里面的新东西,那不就等于没用?jdk8有许多的新特性,详细可看下面脑图 我只讲两个最重要的特性Lambda和Stram,配合起来用可以极 ...

  7. java8新特性——并行流与顺序流

    在我们开发过程中,我们都知道想要提高程序效率,我们可以启用多线程去并行处理,而java8中对数据处理也提供了它得并行方法,今天就来简单学习一下java8中得并行流与顺序流. 并行流就是把一个内容分成多 ...

  8. Java8新特性探索之Stream接口

    一.为什么引入Stream流 流是一系列与特定存储机制无关的元素--实际上,流并没有"存储"之说.使用流,无需迭代集合中的元素,就可以从管道提取和操作元素.这些管道通常被组合在一起 ...

  9. Java8新特性之三:Stream API

    Java8的两个重大改变,一个是Lambda表达式,另一个就是本节要讲的Stream API表达式.Stream 是Java8中处理集合的关键抽象概念,它可以对集合进行非常复杂的查找.过滤.筛选等操作 ...

随机推荐

  1. [PHP学习教程 - 网络]002.$_SERVER["SCRIPT_NAME"]、$_SERVER["PHP_SELF"]、$_SERVER["QUERY_STRING"]、$_SERVER["REQUEST_URI"]介绍($_SERVER URL Infomation)

    引言:在使用原生PHP的时候,对于URL路径的切割,如:域名,查询参数等等的提取,通常绝大多数兄弟会忽略$_SERVER中定义的内置常量的关系,这里为大家讲解一下. 常用的URL请求路径$_SERVE ...

  2. [PHP插件教程]002.代码包PHP Beautifier的使用

    This program reformat and beautify PHP source code files automatically. The program is Open Source a ...

  3. 离散的差分进化Discrete DE

    一般的差分算法的变异规则:Xmutation=Xr1+F(Xr2-Xr3),F为缩放因子, 离散差分进化DDE的变异规则:设每个解为K个元素的集合,则Xr2-Xr3:求出Xr2与Xr3有m个共同元素, ...

  4. 微软:悬赏10万美金破解 Linux 系统

    微软选择了 Linux 系统作为物联网平台,并且悬赏10万美金邀请黑客来进行破解. 当然,该悬赏计划不是针对所有的 Linux 系统,而是特别针对微软的物联网端对端安全平台Azure Sphere.本 ...

  5. bypass disable_function的方法及蚁剑插件bypass-php-function使用

    bypass disable_function的方法及蚁剑插件bypass-php-function使用 在学习php时,发现有许多函数会对网站或系统造成很大危险隐患,常见的危险函数有: phpinf ...

  6. MyBatis主配置文件

    MyBatis的使用非常简单,使用流程整体可以分成以下四步: public class UserDaoTest { private SqlSessionFactory sqlSessionFactor ...

  7. zabbix通过IPMI监控服务器传感器参数

    一.需求:机房dell服务器和IBM服务器皆有主板管理接口iDRAC和iMM,上周已为服务器管理接口配置了ip地址,考虑通过zabbix实现对服务器传感器参数的实时监控.使用DELL-DL1300服务 ...

  8. python常见面试题讲解(十三)字串的连接最长路径查找

    输入描述: 输入第一行为一个正整数n(1≤n≤1000),下面n行为n个字符串(字符串长度≤100),字符串中只含有大小写字母. 输出描述: 数据输出n行,输出结果为按照字典序排列的字符串. 示例1 ...

  9. 从0开始探究vue-公共变量的管理

    背景 在Vue项目中,我们总会遇到一些公共数据的处理,如方法拦截,全局变量等,本文旨在解决这些问题 解决方案 事件总线 所谓事件总线,就是在当前的Vue实例之外,再创建一个Vue实例来专门进行变量传递 ...

  10. Java实现 LeetCode 735 行星碰撞(栈)

    735. 行星碰撞 给定一个整数数组 asteroids,表示在同一行的行星. 对于数组中的每一个元素,其绝对值表示行星的大小,正负表示行星的移动方向(正表示向右移动,负表示向左移动).每一颗行星以相 ...