一、Stream 流

1.1 概念

官方解释:可以支持顺序和并行对元素操作的元素集合。

简单来讲,Stream 就是 JDK8 提供给我们的对于元素集合统一、快速、并行操作的一种方式。

它能充分运用多核的优势,以及配合 Lambda 表达式、链式结构对集合等进行许多有用的操作。

1.2 特征

  • Pipelining: 所有中间操作都会返回流对象本身,这样多个操作可以串联成一个管道。
  • 内部迭代: 通过 Iterator 或者增强 for 的形式在集合外部进行迭代的操作叫做外部迭代,而 Stream提供了内部迭代的方法,流可以直接调用遍历方法。

当使用一个流的时候,通常需要三个步骤:

获取数据源 --> 数据转换 --> 执行操作

每次转换操作时,原有的 Stream 对象不改变,返回一个新的 Stream对象。

二、获取流

java.util.stream.Stream<T> 是 Jdk 8 新添加的流接口(并不是一个函数式接口),通常有以下几种常用方式:

  • 所有的 Collection 集合都可以通过 Stream 默认方法获取流;
  • Stream 接口的静态方法 of 可以获取数组对应的流。

2.1 根据 Collection 获取流

public class DemoGetStream {

    public static void main(String[] args) {

        List<String> list = new ArrayList<>();
Stream<String> listStream = list.stream(); Set<String> set = new HashSet<>();
Stream<String> setStream = set.stream(); } }

2.2 根据 Map 获取流

public class DemoGetStream {

    public static void main(String[] args) {
Map<String,Object> map = new HashMap<>();
Stream<String> keyMapStream = map.keySet().stream();
Stream<Object> valueMapStream = map.values().stream();
Stream<Map.Entry<String, Object>> entryStream = map.entrySet().stream();
} }

2.3 根据数组获取流

public class DemoGetStream {

    public static void main(String[] args) {
String[] strArray = {"a","b","c"};
Stream<String> strStream= Stream.of(strArray);
Integer[] intArray = {1,2,-3,44,100};
Stream<Integer> intStream= Stream.of(intArray);
} }

三、常用方法

Stream 有很多操作方法,分为两种类型:

  • 延迟方法: 返回值类型仍然是 Stream 接口自身类型的方法,因此支持链式调用。
  • 终结方法: 返回值类型不再是 Stream 接口自身类型的方法,因此不支持链式调用。
方法名称 方法类型 作用 方法含义
forEach 终结方法 循环 接收一个 Consumer 对象,将每一个流元素交给该函数进行处理
filter 延迟方法 过滤 接收一个 Predicate 对象 作为筛选条件,将一个流筛选为另一个流
map 延迟方法 映射 接收一个 Function 对象,将当前流中的 T 类型数据转换为 R 类型的流
count 终结方法 统计 统计流中的个数
limit 延迟方法 取前几个对象 对流进行截取,只取前 N 个对象
skip 延迟方法 跳过前几个对象 对流进行截取,跳过前 N 个对象
concat 延迟方法 组合 将两个流合并成一个流

3.1 forEach 方法

格式:

void forEach(Consumer<? super T> action);

实例:

public class DemoStreamForEach {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("三国演义","红楼梦","西游记","三字经");
stream.forEach(s -> System.out.println(s));
} }

3.2 filter 方法

格式:

Stream<T> filter(Predicate<? super T> predicate);

实例:

public class DemoStreamFilter {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("三国演义", "红楼梦", "西游记", "三字经");
stream
.filter(s -> s.contains("三"))
.forEach(s -> System.out.println(s));
} }

3.3 map 方法

格式:

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

实例:

public class DemoStreamMap {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("10", "2", "33");
Stream<Integer> integerStream = stream.map(s -> Integer.parseInt(s));
} }

3.4 count 方法

格式:

long count();

实例:

public class DemoStreamCount {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("三国演义", "红楼梦", "西游记", "三字经");
System.out.println(stream.count()); } }

3.5 limit 方法

格式:

Stream<T> limit(long maxSize);

实例:

public class DemoStreamLimit {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("三国演义", "红楼梦", "西游记", "三字经");
stream
.limit(3)
.forEach(s -> System.out.println(s));
} }

3.6 skip 方法

格式:

Stream<T> skip(long n);

实例:

public class DemoStreamSkip {

    public static void main(String[] args) {
Stream<String> stream = Stream.of("三国演义", "红楼梦", "西游记", "三字经");
stream
.skip(3)
.forEach(s -> System.out.println(s));
} }

3.7 concat 方法

格式:

static <T> Stream<T> concat(Stream<? extends T> a,Stream<? extends T> b);

实例:

public class DemoStreamConcat {

    public static void main(String[] args) {
Stream<String> chinaBooksStream = Stream.of("三国演义", "红楼梦", "西游记", "三字经");
Stream<String> foreignBooksStream = Stream.of("悲惨世界", "哈里波特");
Stream
.concat(chinaBooksStream, foreignBooksStream)
.forEach(s -> System.out.println(s));
} }

Lambda学习总结(二)--Stream流的更多相关文章

  1. (六)jdk8学习心得之Stream流

    六.Stream流 1. 什么是stream流 现阶段,可以把stream流看成一个高级版的Iterator.普通的Iterator只能实现遍历,遍历做什么,就需要具体些功能代码函数了.而这个stre ...

  2. Java8系列 (二) Stream流

    概述 Stream流是Java8新引入的一个特性, 它允许你以声明性方式处理数据集合, 而不是像以前的指令式编程那样需要编写具体怎么实现. 比如炒菜, 用指令式编程需要编写具体的实现 配菜(); 热锅 ...

  3. java8新特性学习笔记(二) 使用流(各种API)

    筛选和切片 用谓词筛选,筛选出各个不相同的元素,忽略流中的头几个元素,或将流截断至指定长度 用谓词筛选 Stream接口支持filter方法,该操作接受一个谓词(返回一个boolean的函数) 作为参 ...

  4. DirectSound学习(二)--流式缓冲区

    使用流式缓冲方式播放波形音频文件比较复杂,主要原因是在只有一个缓冲区提供给用户的前提下,这个缓冲区在提供给声卡播放数据的同是还需要用户不断的定时向其中写入数据.要注意从缓冲区这时是一个环形缓冲区,声音 ...

  5. easylogging++学习记录(二):流式日志

    easylogging++日志库流式日志的写入,依赖于el::base::Writer类的析构,以debug日志为例:具体代码如下: #define LOG(LEVEL) CLOG(LEVEL, EL ...

  6. 第46天学习打卡(四大函数式接口 Stream流式计算 ForkJoin 异步回调 JMM Volatile)

    小结与扩展 池的最大的大小如何去设置! 了解:IO密集型,CPU密集型:(调优)  //1.CPU密集型 几核就是几个线程 可以保持效率最高 //2.IO密集型判断你的程序中十分耗IO的线程,只要大于 ...

  7. JAVA8学习——从使用角度深入Stream流(学习过程)

    Stream 流 初识Stream流 简单认识一下Stream:Stream类中的官方介绍: /** * A sequence of elements supporting sequential an ...

  8. 010-jdk1.8版本新特性二-Optional类,Stream流

    1.5.Optional类 1.定义 Optional 类是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象. Optional 是个 ...

  9. 深度分析:java8的新特性lambda和stream流,看完你学会了吗?

    1. lambda表达式 1.1 什么是lambda 以java为例,可以对一个java变量赋一个值,比如int a = 1,而对于一个方法,一块代码也是赋予给一个变量的,对于这块代码,或者说被赋给变 ...

随机推荐

  1. go中的数据结构-字典map

    1. map的使用 golang中的map是一种数据类型,将键与值绑定到一起,底层是用哈希表实现的,可以快速的通过键找到对应的值. 类型表示:map[keyType][valueType] key一定 ...

  2. Vue中的slot

    个人理解:是对组件的扩展,通过slot插槽向组件内部指定位置传递内容,通过slot可以父子传参: Slot的通俗理解 是“占坑”,在组件模板中占好了位置,当使用该组件标签时候,组件标签里面的内容就会自 ...

  3. pthon基础知识(索引、切片、序列相加、乘法、检查元素是否是序列成员、计算序列长度、最大最小值)

    序列   数据存储方式  数据结构 python 列表.元组.字典.集合.字符串 序列: 一块用于存放多个值的连续内存空间,并且按一定顺序排列,可以通过索引取值 索引(编号): 索引可以是负数 从左到 ...

  4. Python3 Selenium自动化web测试 ==> 第二节 页面元素的定位方法 <上>

    前置步骤: 上一篇的Python单元测试框架unittest,我认为相当于功能测试测试用例设计中的用例模板,在自动化用例的设计过程中,可以封装一个模板,在新建用例的时候,把需要测试的步骤添加上去即可: ...

  5. 【ABAP系列】SAP ABAP 带有参数的AMDP的创建

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 带有参数的AM ...

  6. 云计算Openstack介绍(1)

    一.云计算的前世今生 所有的新事物都不是突然冒出来的,都有前世和今生.云计算也是IT技术不断发展的产物. 要理解云计算,需要对IT系统架构的发展过程有所认识. 请看下 IT系统架构的发展到目前为止大致 ...

  7. netcore程序部署 ubuntu 16.0.4 报错 The type initializer for 'System.Net.Http.CurlHandler'的解决方案

    最近业务扩展需要把netcore程序部署到ubuntu 16.0.4上,因为代码里面用到了HttpClient 请求. 部署ubuntu后一直报错 参考地址:https://github.com/do ...

  8. LeetCode | DP专题详解

    221 medium     221. Maximal Square Medium Given a 2D binary matrix filled with 0's and 1's, find the ...

  9. sftp服务器配置

    环境依赖:openssh-server >=4.8 //ssh -V 查看 安装环境: centos6,centos7 1.创建用户组 sftp    groupadd sftp 2.创建登录用 ...

  10. [Python3] 040 文件 一般使用

    目录 文件 1. open 函数 2. with 语句 3. 先写再读 3.1 写 3.2 读 4. "位置"的查询与移动 4.1 tell() 4.2 seek(cookie, ...