Java8——Stream流
Stream是数据渠道,用于操作集合、数组等生成的元素序列。
Stream操作的三个步骤:
创建Stream
中间操作
终止操作
一、获取stream的四种方式
- 通过
collection系列集合的stream()或parallelStream()获取。
@Test
void test11(){
List<String> list = new ArrayList<>();
Stream<String> stringStream = list.stream();
}
- 通过
Arrays中的静态方法stream()获取数组流。
@Test
void test11(){
Person[] person = new Person[10];
Arrays.stream(person);
}
- 通过
Stream中的静态方法of()。
@Test
void test11(){
Stream<String> stream = Stream.of("a", "b", "c");
}
- 创建无限流
/**
* 迭代
*/
@Test
void test11(){
Stream<Integer> integerStream = Stream.iterate(0, x -> x + 2);
}
/**
* 生成
*/
@Test
void test11(){
Stream.generate(() -> Math.random());
}
二、中间操作
中间操作不会执行任何操作,只有终止操作才会一次性输出全部值,即“惰性求值”。
2.1 筛选与切片
filter——接收lamdba,从流中排除某些元素
@Test
void test12(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20)
);
// 中间操作
Stream<Person> personStream = personList.stream()
.filter(e -> e.getAge() > 18);
// 终止操作
personStream.forEach(System.out::println);
}
limit——截断流,使其元素不超过给定数量
@Test
void test12(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20)
);
personList.stream()
.limit(1)
.forEach(System.out::println);
}
skip(n)——跳过元素,返回一个扔掉前n个元素的流,若不足n个,则返回一个空流。与limit(n)互补。
@Test
void test12(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20)
);
personList.stream()
.skip(1)
.forEach(System.out::println);
}
distinct——筛选,通过生成元素的hashCode()和equals(),去除重复元素。
@Test
void test12(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20),
new Person("Java旅途",20)
);
personList.stream()
.distinct()
.forEach(System.out::println);
}
注意:使用distinct的时候需要重写实体的hashCode()和equals()方法。
2.2 映射
map——接收lamdba,将元素转换成其他形式或提取信息。接收一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素。
/**
* 获取personList的所有name
*/
@Test
void test13(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20),
new Person("Java旅途",20)
);
personList.stream()
.map(Person::getName)
.forEach(System.out::println);
}
flatMap——接收一个函数作为参数,将流中的每个值都换成另一个流,然后把所有流生成一个流。
// 将字符串转换为字符,并将字符放进list返回
static Stream<Character> filterCharcter(String string){
List<Character> list = new ArrayList<>();
for (Character ch : string.toCharArray()){
list.add(ch);
}
return list.stream();
}
@Test
void test13(){
List<String> list = Arrays.asList("aaa","bbb","ccc");
list.stream()
.flatMap(LamdbaApplicationTests::filterCharcter)
.forEach(System.out::println);
}
2.3 排序
sorted()——自然排序(comparable)sorted(comparator com)——定制排序(comparator )
/**
* 定制排序,e1和e2按age排序,age一样按name排
*/
@Test
void test14(){
List<Person> personList = Arrays.asList(
new Person("Java旅途",18),
new Person("Java旅途",20)
);
personList.stream()
.sorted((e1,e2) -> {
if(e1.getAge() == e2.getAge()){
return e1.getName().compareTo(e2.getName());
}else{
return e1.getAge()+"".compareTo(e2.getAge()+"");
}
}).forEach(System.out::println);
}
三、终止操作
3.1 查找与匹配
完善一下Person类
@Data
public class Person implements Serializable {
private static final long serialVersionUID = -7008474395345458049L;
private String name;
private int age;
private Status status;
public Person() {
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person(String name, int age, Status status) {
this.name = name;
this.age = age;
this.status = status;
}
public enum Status {
FRER,
BUSY;
}
}
allMatch——检查是否匹配所有元素
/**
* 是否所有元素都是Fire状态,是返回true
*/
@Test
void test15(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
boolean b = personList1.stream()
.allMatch(e -> e.getStatus().equals(Person.Status.FRER));
System.out.println(b);
}
anyMatch——检查是否至少匹配一个元素
@Test
void test15(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
boolean b = personList1.stream()
.anyMatch(e -> e.getStatus().equals(Person.Status.FRER));
System.out.println(b);
}
noneMatch——检查是否所有元素都不匹配
@Test
void test15(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
boolean b = personList1.stream()
.noneMatch(e -> e.getStatus().equals(Person.Status.FRER));
System.out.println(b);
}
findFirst——返回第一个元素
@Test
void test15(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
Optional b = personList1.stream()
.findFirst();
System.out.println(b.get());
}
findAny——返回当前流中的任意元素
@Test
void test15(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
Optional b = personList1.stream()
.findAny();
System.out.println(b.get());
}
count——返回流中元素的总数max——返回流中最大值min——返回流中最小值
3.2 规约
reduce(T identity, BinaryOperator)/reduce(BinaryOperator)——可以将流中元素反复结合起来,得到一个值。
/**
* reduce 第一个参数是起始值
*/
@Test
void test16(){
List<Integer> list = Arrays.asList(1,2,3,4,5,6,7,8,9,10);
Integer sum = list.stream()
.reduce(0,(x,y) -> x+y);
System.out.println(sum);
Optional<Integer> reduce = list.stream()
.reduce((x, y) -> x + y);
System.out.println(reduce.get());
}
3.3 收集
collect——将流转化为其他形式。接收一个Collector接口的实现。用于给Stream中元素做汇总的方法。
/**
* 取出名字放在一个list中
*/
@Test
void test16(){
List<Person> personList1 = Arrays.asList(
new Person("Java旅途",18, Person.Status.FRER),
new Person("Java旅途",20, Person.Status.BUSY)
);
List<String> collect = personList1.stream()
.map(Person::getName)
.collect(Collectors.toList());
collect.forEach(System.out::println);
}
Optional常用方法
Optional类是一个容器类,代表一个值存在或不存在,原来用null表示一个值不存在,现在Optional可以更好的表达这个概念。并且可以避免空指针异常。
Optional.of(T t) ——创建一个Optional实例
Optional.empty()——创建一个空的optional实例
Optional.ofNullable(T t)——若t不为null,创建optional实例,否则创建空实例
isPresent()——判断是否包含值
orElse(T t)——如果调用对象包含值,返回该值,否则返回 t
orElseGet(Supplier s)——如果调用对象包含值,返回该值,否则返回 s 获取的值
map(Function f)——如果有值对其处理,并返回处理后的Optional,否则返回Optional.empty()
flatMap(Function mapper)——与map类似,要求返回值必须是Optional
Java8——Stream流的更多相关文章
- 【转】Java8 Stream 流详解
当我第一次阅读 Java8 中的 Stream API 时,说实话,我非常困惑,因为它的名字听起来与 Java I0 框架中的 InputStream 和 OutputStream 非常类似.但是 ...
- Java8 Stream流
第三章 Stream流 <Java8 Stream编码实战>的代码全部在https://github.com/yu-linfeng/BlogRepositories/tree/master ...
- 关于Java8 Stream流的利与弊 Java初学者,大神勿喷
题目需求: 1:第一个队伍只要名字为3个字成员的姓名,存储到新集合 2:第一个队伍筛选之后只要前3人:存储到一个新集合 3:第2个队伍只要姓张的成员姓名:存储到一个新集合 4:第2个队伍不要前2人,存 ...
- Java8 Stream流API常用操作
Java版本现在已经发布到JDK13了,目前公司还是用的JDK8,还是有必要了解一些JDK8的新特性的,例如优雅判空的Optional类,操作集合的Stream流,函数式编程等等;这里就按操作例举一些 ...
- Java8——Stream流式操作的一点小总结
我发现,自从我学了Stream流式操作之后,工作中使用到的频率还是挺高的,因为stream配合着lambda表达式或者双冒号(::)使用真的是优雅到了极致!今天就简单分(搬)享(运)一下我对strea ...
- 【JDK8】Java8 Stream流API常用操作
Java版本现在已经发布到JDK13了,目前公司还是用的JDK8,还是有必要了解一些JDK8的新特性的,例如优雅判空的Optional类,操作集合的Stream流,函数式编程等等;这里就按操作例举一些 ...
- Java8 Stream流方法
流是Java API的新成员,它允许以声明性方式处理数据集合(通过查询语句来表达,而不是临时编写一个实现).就现在来说,可以把它们看成遍历数据集的高级迭代器.此外,流还可以透明地并行处理,无需写任何多 ...
- Java8 - Stream流:让你的集合变得更简单!
前段时间,在公司熟悉新代码,发现好多都是新代码,全是 Java8语法,之前没有了解过,一直在专研技术的深度,却忘了最初的语法,所以,今天总结下Stream ,算是一份自己理解,不会很深入,就讲讲常用的 ...
- java8 stream 流 例子
Trader raoul = new Trader("Raoul", "Cambridge"); Trader mario = new Trader(" ...
- Java8 Stream 流使用场景和常用操作
JAVA8内置的函数式编程接口应用场景和方式 pojo类对象和默认创建list的方法 import lombok.AllArgsConstructor; import lombok.Data; imp ...
随机推荐
- matlab中imwrite函数详解(imwrite的输出格式)
参考资料: https://www.mathworks.com/help/matlab/ref/imwrite.html?s_tid=srchtitle 你可能觉得imread函数很简单,但是还是有一 ...
- Laravel模板引擎Blade中section的一些标签的区别介绍
Laravel 框架中的 Blade 模板引擎,很好用,但是在官方文档中有关 Blade 的介绍并不详细,有些东西没有写出来,而有些则是没有说清楚.比如,使用中可能会遇到这样的问题: 1.@yield ...
- 循序渐进VUE+Element 前端应用开发(12)--- 整合ABP框架的前端登录处理
VUE+Element 前端是一个纯粹的前端处理,前面介绍了很多都是Vue+Element开发的基础,从本章随笔开始,就需要进入深水区了,需要结合ABP框架使用(如果不知道,请自行补习一下我的随笔:A ...
- Beta冲刺总结随笔
这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 团队名称 WeChair 这个作业要求在哪里 Beta冲刺 这个作业的目标 Beta冲刺 作业正文 如下 其他参考文献 项目预期 ...
- Struts2 执行流程 以及 Action与Servlet比较 (个人理解)
上图提供了struts2的执行流程.如下: 1:从客户端发出请求(HTTPServletRequest). 2:请求经过各种过滤器(filter),注:一般情况下,如SiteMesh等其他过滤器要放在 ...
- RabbitMQ:一、入门
消息中间件 使用消息中间件的作用 解耦 削峰 异步 顺序保证 冗余(存储) RabbitMQ的特点 可靠性 灵活的路由 扩展性 高可用 多语言客户端 插件机制 多协议(主要还是AMQP) 相关概念 P ...
- Redis持久化机制,优缺点,如何选择合适方式
一.什么是Redis持久化? 持久化就是把内存的数据写到磁盘中去,防止服务宕机了内存数据丢失. 二.Redis 的持久化机制是什么?各自的优缺点? Redis 提供两种持久化机制 RDB(默认) 和 ...
- 《HelloGitHub》第 51 期
兴趣是最好的老师,HelloGitHub 就是帮你找到兴趣! 简介 分享 GitHub 上有趣.入门级的开源项目. 这是一个面向编程新手.热爱编程.对开源社区感兴趣 人群的月刊,月刊的内容包括:各种编 ...
- 【python + NATAPP】实现内网穿透的简易数据传输
1. 服务端 接收两张图像的地址,返回这两张图像的相似度 import os, shutil, requests import cv2 import numpy as np import imgs_s ...
- Scrapy框架简介及小项目应用
今天来总结一下Scrapy框架的用法.scrapy的架构如下: Engine :引擎,处理整个系统的数据流处理.触发事务,是整个框架的核心. Items :项目,它定义了爬取结果的数据结构,爬取的数 ...