什么是 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());
}

最新文章

  1. 拍拍装修&lt;a href=&quot;&quot; &gt; 搜狐 “兼容模式”下失效,解决办法
  2. yii框架部署
  3. 西川善司【神秘海域(Uncharted)】的图形分析
  4. HDU 5618 Jam&#39;s problem again CDQ分治 BC ROUND 70
  5. nand烧写分析/内核在启动过程中式如何将这个文件映射成/目录及各子目录的?
  6. poj 1206
  7. brutal是什么意思_brutal在线翻译_英语_读音_用法_例句_海词词典
  8. 在Linux下访问Windows共享目录的配置方法
  9. 关于MFC中InvalidateRect()的思考与疑问
  10. JS学习笔记——数组去重
  11. spring AOP 和自定义注解进行身份验证
  12. Google官方网络框架-Volley的使用解析Json以及加载网络图片方法
  13. Python练手例子(10)
  14. java 开发环境配置 安装 MyEclipse
  15. test markdown to html
  16. vue 路由配置
  17. python --端点调试
  18. CEF 跨域访问iframe
  19. Luogu4173 残缺的字符串 FFT
  20. 使用ado.net打造通用的数据库操作类

热门文章

  1. javascript语言精粹数组篇之Array的方法注意事项
  2. Badboy - 导出脚本,用于JMeter并发测试
  3. 杭电第六场 hdu6362 oval-and-rectangle 积分求期望
  4. Caused by: com.fasterxml.jackson.databind.exc.InvalidDefinitionException: No serializer found for class org.apache.catalina.connector.CoyoteWriter and no properties discovered to create BeanSerializer
  5. 携程PMO--小罗说敏捷之WIP限制在制品
  6. HDU 1015 Safecracker (DFS)
  7. 1、pytest中文文档--安装和入门
  8. Java连载29-方法执行内存分析、方法重载
  9. Linux OOM-killer(内存不足时kill高内存进程的策略)
  10. virtualbox下最小化安装centos7后上网设置