JAVA 8 新特性Stream初体验
什么是 Stream?
Stream(流)是一个来自数据源的元素队列并支持聚合操作
- <strong元素队列< strong="">元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。
- 数据源 流的来源。 可以是集合,数组,I/O channel, 产生器generator 等。
- 聚合操作 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
和以前的Collection操作不同, Stream操作还有两个基础的特征:
- Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
- 内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。
题目:
有一个集合,里面存放字符串如:"小王,98"、"小李,95"、"小陈,87",要求打印输出所有成绩当中大于90分的数字。
常规写法
public static void main(String[] args) {
ArrayList<String> arrayList=new ArrayList<String>();
arrayList.add("小王,98");
arrayList.add("小李,95");
arrayList.add("小陈,87");
for (int i = ; i < arrayList.size(); i++) {
String record=arrayList.get(i);
String score=record.split(",")[];
int num =Integer.parseInt(score);
if (num>) {
System.out.println(num);
}
}
}
Stream方式
public static void main(String[] args) {
ArrayList<String> arrayList=new ArrayList<String>();
arrayList.add("小王,98");
arrayList.add("小李,95");
arrayList.add("小陈,87");
arrayList.stream().map(s->s.split(",")[]).map(Integer::parseInt)
.filter(n -> n > ).forEach(System.out::println);
}
Stream方法详细介绍
public static void main(String[] args) {
//1.根据集合获取流
ArrayList<String> arrayList=new ArrayList<String>();
arrayList.add("小陈");
arrayList.add("小王");
arrayList.add("小李");
Stream<String> streamA=arrayList.stream(); //2.根据数组获取流,数组当中的元素必须是引用类型才行
String[] arrayStr= {"Hello","World","Java"};
Stream<String> streamB=Stream.of(arrayStr); Integer[] arrayIntegers= {10,20,30};
Stream<Integer> streamC=Stream.of(arrayIntegers);
}
几种获取流方式
一、生成流
stream() − 为集合创建串行流。
parallelStream() − 为集合创建并行流。
串行流
public static void main(String[] args) {
//生成流,并筛选出不是空字符串的集合
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd", "", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());
for (int i = ; i < filtered.size(); i++) {
System.out.println(filtered.get(i));
}
}
并行流
public static void main(String[] args) {
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
// 获取空字符串的数量
long count = strings.parallelStream().filter(string -> string.isEmpty()).count();
System.out.println(count);
}
二、forEach
- Stream 提供了新的方法 'forEach' 来迭代流中的每个数据。
public static void main(String[] args) {
//使用forEach遍历打印集合中的数字
ArrayList<Integer> arrayList=new ArrayList<Integer>();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.stream().forEach(System.out::println);
}
三、map
- map 方法用于映射每个元素到对应的结果,以下代码片段使用 map 输出了元素对应的平方数:
public static void main(String[] args) {
//使用map输出元素对应的平方
List<Integer> numbers = Arrays.asList(,,,,,);
numbers.stream().map(i->i*i).forEach(System.out::println);
}
四、filter
- filter 方法用于通过设置的条件过滤出元素。
public static void main(String[] args) {
//使用 filter 方法过滤空字符串的个数
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
long count = strings.stream().filter(string -> string.isEmpty()).count();
System.out.println(count);
}
五、limit
- limit 方法用于获取指定数量的流。
public static void main(String[] args) {
//使用 limit 方法打印出 3 条数据:
ArrayList<Integer> arrayList = new ArrayList<Integer>();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.stream().limit().forEach(System.out::println);
}
六、sorted
- sorted 方法用于对流进行排序。以下代码片段使用 sorted 方法对输出的 10 个随机数进行排序:
public static void main(String[] args) {
//使用 sorted 方法集合中的元素排序:
ArrayList<Integer> arrayList = new ArrayList<Integer>();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.add();
arrayList.stream().sorted().forEach(System.out::println);
}
七、Collectors
- Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。Collectors 可用于返回列表或字符串:
public static void main(String[] args) {
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd", "", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList()); System.out.println("筛选列表: " + filtered);
String mergedString = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.joining(", "));
System.out.println("合并字符串: " + mergedString);
}
八、统计
- 一些产生统计结果的收集器也非常有用。它们主要用于int、double、long等基本类型上,它们可以用来产生类似如下的统计结果。
public static void main(String[] args) {
List<Integer> numbers = Arrays.asList(, , , , , , ); IntSummaryStatistics stats = numbers.stream().mapToInt((x) -> x).summaryStatistics(); System.out.println("列表中最大的数 : " + stats.getMax());
System.out.println("列表中最小的数 : " + stats.getMin());
System.out.println("所有数之和 : " + stats.getSum());
System.out.println("平均数 : " + stats.getAverage());
}
JAVA 8 新特性Stream初体验的更多相关文章
- Java 8 新特性-Stream更优雅的处理集合入门
Java 8 新特性之--Stream 一. 简单介绍 Stream是Java 8提出了的一种新的对集合对象功能的增强.它集合Lambda表达式,对集合提供了一些非常便利,高效的操作,使得代码具有非常 ...
- 再来看看Java的新特性——Stream流
半年前开始试着使用Java的新特性,给我印象最深的就是Stream流和Optional.其中Stream提高了看法效率,让代码看起来十分清爽. 为什么要使用流? 摘要中已经说明了,为了提高开发效率.流 ...
- Java 8 新特性---------Stream
Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据. Stream使用一种类似用SQL语句从数据库查询数据的直观方式来提供一种对Java集合运算和表达的高阶抽象 ...
- Java 8新特性--Stream API
Java 8 API添加了一个新的抽象称为流Stream,以一种声明的方式处理数据,可以极大提高程序员的生产力,写出高效.干净.简洁的代码.这种风格将要处理的元素集合看作一种流,流在管道中传输,并且可 ...
- Java 8 新特性——Lambdas 表达式
本文内容 引入 测试数据 collect(toList()) map filter flatMap max 和 min reduce 整合操作 参考资料 Java 8 对核心类库的改进主要包括集合类的 ...
- Java 12 新特性介绍,快来补一补
Java 12 早在 2019 年 3 月 19 日发布,它不是一个长久支持(LTS)版本.在这之前我们已经介绍过其他版本的新特性,如果需要可以点击下面的链接进行阅读. Java 11 新特性介绍 J ...
- Java 8 新特性之 Stream 流基础体验
Java 8 新特性之 Stream 流基础体验 package com.company; import java.util.ArrayList; import java.util.List; imp ...
- Java 8新特性之旅:使用Stream API处理集合
在这篇“Java 8新特性教程”系列文章中,我们会深入解释,并通过代码来展示,如何通过流来遍历集合,如何从集合和数组来创建流,以及怎么聚合流的值. 在之前的文章“遍历.过滤.处理集合及使用Lambda ...
- java新特性stream
java新特性stream,也称为流式编程. 在学习stream之前先了解一下java内置的四大函数 第一种函数式函数,后面是lambda表达式写法 /*Function<String,Inte ...
随机推荐
- 关于AndroidStudio在真机安装的apk闪退(无法打开)的解决方案
问题描述: 重新安装AndroidStudio之后 1.发现在真机上安装apk时显示的是应用包名. 2.在真机上安装的apk无法打开,一直闪退. 如图: 解决方案: 关闭AndroidStudio的I ...
- Fire Balls 07——砖块的淡出,消失以及砖塔的下落
版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...
- x86—EFLAGS寄存器详解(转载)
鉴于EFLAGS寄存器的重要性,所以将这一部分内容从处理器体系结构及寻址模式一文中单独抽出另成一文,这部分内容主要来自Intel Developer Mannual,在后续的内核系列中遇到的许多和EF ...
- unicode的编码与解码
- 树状数组求区间和模板 区间可修改 参考题目:牛客小白月赛 I 区间
从前有个东西叫树状数组,它可以轻易实现一些简单的序列操作,比如单点修改,区间求和;区间修改,单点求值等. 但是我们经常需要更高级的操作,比如区间修改区间查询.这时候树状数组就不起作用了,只能选择写一个 ...
- Atcoder D - A or...or B Problem(思维)
题目链接:http://agc015.contest.atcoder.jp/tasks/agc015_d 题意:给出两个数b,a(a>=b)问{a,a+1,....,b}的集合内取任意数求或运算 ...
- 快速构建第一个Flink工程
本文简述通过maven和gradle快速构建的Flink工程.建议安装好Flink以后构建自己的Flink项目,安装与示例运行请查看:Flink快速入门--安装与示例运行. 在安装好Flink以后,只 ...
- 【Offer】[3-1] 【找出数组中重复的数字】
题目描述 思路 Java代码 代码链接 题目描述 在一个长度为n的数组里的所有数字都在0~n-1的范围内.数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次. 请找出数组中任 ...
- SpringCloud学习笔记(1):Eureka注册中心
简介 Eureka是Netflix开源的基于rest的服务治理方案,分为Server端和Client端,Server端为注册中心,其他微服务通过Client端连接Server端进行服务的注册和发现. ...
- 【LeetCode】300-最长上升子序列
题目描述 给定一个无序的整数数组,找到其中最长上升子序列的长度. 示例: 输入: [10,9,2,5,3,7,101,18] 输出: 4 解释: 最长的上升子序列是 [2,3,7,101],它的长度是 ...