stream对象

  1. Stream

  2. IntStream

  3. LongStream

  4. DoubleStream

创建

常用的三种方式:

  • 使用list对象:

    • list.stream() − 为集合创建串行流。
    • list.parallelStream() − 为集合创建并行流。
  • Arrays: Arrays.stream( T[] array) − 为数组创建流(可以创建IntStream,LongStream,DoubleStrem)。

  • Stream: Stream.of(T... values) − 为一组同类型的数据创建流。

demo:

 /**
* 集合接口有两个方法来生成流:
* 按照流的类型可分为串行流和并行流
* stream() − 为集合创建串行流。
* parallelStream() − 为集合创建并行流。
*/
private static Stream<String> createStreamFromCollection() {
List<String> list = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
return list.stream();
}
/**
* 使用Stream.of()创建流
* @return
*/
private static Stream<String> createStreamFromValues() {
return Stream.of("hello", "alex", "wangwenjun", "world", "stream");
}
/**
* 使用Arrays.stream()创建流
* 可以生成IntStream,LongStream,DoubleStream
* @return
*/
private static Stream<String> createStreamFromArrays() {
String[] strings = {"hello", "alex", "wangwenjun", "world", "stream"};
return Arrays.stream(strings);
}

操作

filter : 过滤, 过滤掉不符合条件的数据。

map :转换流类型, 返回一个流,该流包含将给定函数应用于该流元素的结果。

​ 比如一个Stream 类型的流组装后成为Stream的流

limit : 分页。

collect : 将流收集成一个数组。

  List<Dish> menu = Arrays.asList(
new Dish("pork", false, 800, "肉类"),
new Dish("beef", false, 700, "肉类"),
new Dish("chicken", false, 400, "肉类"),
new Dish("french fries", true, 530, "鱼肉类"),
new Dish("rice", true, 350, "鱼肉类"),
new Dish("season fruit", true, 120, "鱼肉类"),
new Dish("pizza", true, 550, "鱼肉类"),
new Dish("prawns", false, 300, "其他"),
new Dish("salmon", false, 450, "其他")); //创建菜单流
List<Map<String,Integer>> result = menu.stream().filter(d -> {
// 过滤出卡路里大于300的值
System.out.println("filtering->" + d.getName());
return d.getCalories() > 300;
})
.map(d -> {
Map<String, Integer> map = new HashMap<>();
map.put(d.getName(),d.getCalories());
return map;
})
.limit(3)
.collect(toList()); System.out.println(result);

其他操作

  List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 6, 7, 7, 1);
List<Integer> result = list.stream().filter(i -> i % 2 == 0).collect(toList());
System.out.println("i -> i % 2 的值 : "+result);
result = list.stream().distinct().collect(toList());
System.out.println("去重 : "+result);
result = list.stream().skip(2).collect(toList());//跳过前两个数
System.out.println("跳过 : "+result);
result = list.stream().limit(4).collect(toList());//取前4个值
System.out.println("分页 : "+result);
System.out.println("循环方式一 : ");
list.forEach(i -> System.out.println(i));
System.out.println("循环方式二 : ");
list.forEach((Integer i) -> System.out.println(i));
System.out.println("循环方式三 : ");
list.forEach(System.out::println); for (int i : list) {
System.out.println(i);
}

**** 码字不易如果对你有帮助请给个关注****

**** 爱技术爱生活 QQ群: 894109590****

java8新特性——stream笔记的更多相关文章

  1. java8 新特性学习笔记

    Java8新特性 学习笔记 1主要内容 Lambda 表达式 函数式接口 方法引用与构造器引用 Stream API 接口中的默认方法与静态方法 新时间日期 API 其他新特性 2 简洁 速度更快 修 ...

  2. Java8 新特性 Stream 非短路终端操作

    非短路终端操作 Java8 新特性 Stream 练习实例 非短路终端操作,就是所有的元素都遍厉完,直到最后才结束.用来收集成自己想要的数据. 方法有: 遍厉 forEach 归约 reduce 最大 ...

  3. Java8 新特性 Stream 短路终端操作

    短路终端操作 Java8 新特性 Stream 练习实例 传入一个谓词,返回传为boolean,如果符合条件,则直接结束流. 匹配所有 allMatch 任意匹配 anymMatch 不匹配 none ...

  4. Java8 新特性 Stream 无状态中间操作

    无状态中间操作 Java8 新特性 Stream 练习实例 中间无状态操作,可以在单个对单个的数据进行处理.比如:filter(过滤)一个元素的时候,也可以判断,比如map(映射)... 过滤 fil ...

  5. Java8 新特性 Stream() API

    新特性里面为什么要加入流Steam() 集合是Java中使用最多的API,几乎每一个Java程序都会制造和处理集合.集合对于很多程序都是必须的,但是如果一个集合进行,分组,排序,筛选,过滤...这些操 ...

  6. 这可能是史上最好的 Java8 新特性 Stream 流教程

    本文翻译自 https://winterbe.com/posts/2014/07/31/java8-stream-tutorial-examples/ 作者: @Winterbe 欢迎关注个人微信公众 ...

  7. java8新特性--Stream的基本介绍和使用

    什么是Stream? Stream是一个来自数据源的元素队列并可以进行聚合操作. 数据源:流的来源. 可以是集合,数组,I/O channel, 产生器generator 等 聚合操作:类似SQL语句 ...

  8. Java8新特性Stream流应用示例

    Java8新特性介绍 过滤集合 List<String> newList = list.stream().filter(item -> item != null).collect(C ...

  9. Java8 新特性 Stream 练习实例

    练习实例 配合Java8 新特性 Steam() API 使用 //没有写get set 构造方法 public class Sku { private Integer skuId; private ...

随机推荐

  1. 线性反馈移位寄存器(LFSR)-非线性反馈移位寄存器的verilog实现(产生伪随机数)

    一.线性反馈移位寄存器(LFSR) 通过对事先选定的种子做运算使得人工生成的伪随机序列的过程,在实际中,随机种子的选择决定了输出的伪随机序列的不同,也就是说随机种子的选择至关重要. 产生伪随机数的方法 ...

  2. redis 的雪崩和穿透?

    https://blog.csdn.net/Aria_Miazzy/article/details/88066975

  3. 记一次关于JDBCUtils工具类的编写

    jdbc.properties数据库配置的属性文件内容如下 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost/xxxx ...

  4. 多对多表创建、forms组件、cookie与session

    多对多表的三种创建方式 1.全自动(较为推荐) 优势:不需要你手动创建第三张表 不足:由于第三张表不是你手动创建的,所以表字段是固定的无法扩展 class Book(models.Model): ti ...

  5. 基于TCP的大文件发送、UDP、socketserver

    基于TCP的大文件发送 #server服务端 import struct import json import os import socket server = socket.socket() # ...

  6. iOS路由详解

    本文如题,路由详解,注定是一篇详细解释iOS路由原理及使用的文章,由于此时正在外地出差,无法详细一一写出,只能不定时的补充. 一.什么是iOS路由 路由一词来源于路由器,可以实现层级之间消息转发的功能 ...

  7. 查询AD中被锁定的账号并进行解锁

    1:查询AD中被锁定的账号: Search-ADAccount -LockedOut | export-csv -path c:\aaavvv.csv 2:解除锁定 Search-ADAccount ...

  8. @EnableWebMvc WebMvcConfigurer CorsConfig

    package me.zhengjie.core.config; import org.springframework.context.annotation.Configuration; import ...

  9. Qt Sleep、QCoreApplication::processEvents()(最佳的平衡:一边发送消息,一边睡眠)

    sleep()//秒 msleep()//毫秒 usleep()//微秒 以前为了模拟鼠标点击用过这些函数,可以让进程中断,今天发现我原来的做法其实不对.这组函数会将你当前的线程/进程变为“睡眠”状态 ...

  10. nowcoder-548C-Tachibana Kanade Loves Review

    链接:https://ac.nowcoder.com/acm/contest/548/C来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 524288K,其他语言10485 ...