Stream流

Java 8 API添加了一种新的机制——Stream(流)。Stream和IO流不是一回事。

流式思想:像生产流水线一样,一个操作接一个操作。

使用Stream流的步骤:数据源→转换成流→操作1→操作2→……

数据源(source):可以是集合、数组等。

Stream操作有两个基础特征:

(1)Pipelining(流水线):流操作会返回流对象(新的对象),以便后续继续进行流操作。

(2)内部迭代:不需要像for循环或Iterator一样进行显式的迭代。

import java.util.*;
public class TestStream {
public static void main(String[] args) {
List<String> lst = new ArrayList<>();
lst.add("孙悟空");
lst.add("猪八戒");
lst.add("沙僧");
lst.add("唐僧");
// 需求:(1)筛选名字是3个字的人,(2)输出结果
System.out.println("-----流式写法");
// .stream():把集合转换成流
// .filter的参数是Predicate接口,抽象方法test()方法用于判断
// .forEach的参数是Consumer接口,抽象方法accept()用于接受数据
lst.stream().filter(name -> name.length() == 3)
.forEach(name -> System.out.println(name));
System.out.println("------ 方法引用(关注做什么,不管怎么做)");
printStr(s -> System.out.println(s), "Lambda");
printStr(System.out::println, "方法引用");
}
static void printStr(Printable p, String s) {
p.print(s);
}
}
interface Printable {
void print(String s);
}
-----流式写法
孙悟空
猪八戒
------ 方法引用(关注做什么,不管怎么做)
Lambda
方法引用

获取流

import java.util.*;
import java.util.Map.Entry;
import java.util.stream.Stream;
public class GetStream {
public static void main(String[] args) {
// List和Set
Collection<String> c = new ArrayList<>();
Stream stream = c.stream();
// Map(分k,v,k&v三种)
Map<String, String> map = new HashMap<>();
Stream<String> stream2 = map.keySet().stream();
Stream<String> stream3 = map.values().stream();
Stream<Entry<String, String>> stream4 = map.entrySet().stream();
// 数组
Integer[] arr = { 1, 2, 3, 4, 5 };
Stream<Integer> stream5 = Stream.of(arr);
}
}

常用方法

延迟方法:返回值还是Stream接口类型。

终结方法:返回类型不是Stream。如count和forEach。

import java.util.stream.Stream;
public class TestStream {
public static void main(String[] args) {
System.out.println("-- void forEach(Consumer),accept(T)获取参数");
Stream<Integer> stream = Stream.of(1, 2, 3, 4, 5);
stream.forEach(e -> System.out.println(e));
// -------------
System.out.println("-- Stream filter(Predicate),test(T)用于判断");
// 必须重新获取流,因为Stream只能被使用一次,数据流到下一个Stream上。
// 如果不重新获取,会得到异常:stream has already been operated upon or closed
stream = Stream.of(1, 2, 3, 4, 5);
Stream<Integer> stream2 = stream.filter(e -> e % 2 == 0);
stream2.forEach(e -> System.out.println(e));
// -------------
stream = Stream.of(1, 2, 3, 4, 5);
System.out.println("-- Stream map(Function),R apply(T t),类型转换");
Stream<String> stream3 = stream.map(n -> "第" + n);
stream3.forEach(e -> System.out.println(e));
// -------------
stream = Stream.of(1, 2, 3, 4, 5);
System.out.println("-- Stream limit(long maxSize):取前maxSize个");
Stream<Integer> limit = stream.limit(3);
limit.forEach(e -> System.out.println(e));
// -------------
stream = Stream.of(1, 2, 3, 4, 5);
System.out.println("-- Stream skip(long n):跳过前n个");
Stream<Integer> skip = stream.skip(1);
skip.forEach(e -> System.out.println(e));
// -------------
stream = Stream.of(1, 2, 3, 4, 5);
Stream<Integer> stream4 = Stream.of(11, 12, 13);
System.out.println("-- Stream concat(Stream a, Stream b):二流归一");
Stream<Integer> concat = Stream.concat(stream, stream4);
concat.forEach(e -> System.out.println(e));
// -------------
stream = Stream.of(1, 2, 3, 4, 5);
System.out.println("-- long count():终结方法");
long count = stream.count();
System.out.println(count);
}
}
-- void forEach(Consumer),accept(T)获取参数
1
2
3
4
5
-- Stream filter(Predicate),test(T)用于判断
2
4
-- Stream map(Function),R apply(T t),类型转换
第1
第2
第3
第4
第5
-- Stream limit(long maxSize):取前maxSize个
1
2
3
-- Stream skip(long n):跳过前n个
2
3
4
5
-- Stream concat(Stream a, Stream b):二流归一
1
2
3
4
5
11
12
13
-- long count():终结方法
5

Java基础教程——Stream的更多相关文章

  1. Java基础教程:Lambda表达式

    Java基础教程:Lambda表达式 本文部分内容引用自OneAPM:http://blog.oneapm.com/apm-tech/226.html 引入Lambda Java 是一流的面向对象语言 ...

  2. Java基础教程:JDBC编程

    Java基础教程:JDBC编程 1.什么是JDBC JDBC 指 Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库. JDBC A ...

  3. Java基础(十一) Stream I/O and Files

    Java基础(十一) Stream I/O and Files 1. 流的概念 程序的主要任务是操纵数据.在Java中,把一组有序的数据序列称为流. 依据操作的方向,能够把流分为输入流和输出流两种.程 ...

  4. Java基础教程(18)--继承

    一.继承的概念   继承是面向对象中一个非常重要的概念,使用继承可以从逻辑和层次上更好地组织代码,大大提高代码的复用性.在Java中,继承可以使得子类具有父类的属性和方法或者重新定义.追加属性和方法. ...

  5. Java基础教程(12)--深入理解类

    一.方法的返回值   当我们在程序中调用方法时,虚拟机将会跳转到对应的方法中去执行.当以下几种情况发生时,虚拟机将会回到调用方法的语句并继续向下执行: 执行完方法中所有的语句: 遇到return语句: ...

  6. Java基础教程:注解

    Java基础教程:注解 本篇文章参考的相关资料链接: 维基百科:https://zh.wikipedia.org/wiki/Java%E6%B3%A8%E8%A7%A3 注解基础与高级应用:http: ...

  7. Java基础教程:网络编程

    Java基础教程:网络编程 基础 Socket与ServerSocket Socket又称"套接字",网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个s ...

  8. Java基础教程(5)--变量

    一.变量 1.变量的定义   正如上一篇教程<Java基础教程(4)--面向对象概念>中介绍的那样,对象将它的状态存在域中.但是你可能仍然有一些疑问,例如:命名一个域的规则和惯例是什么?除 ...

  9. Java基础教程:泛型基础

    Java基础教程:泛型基础 引入泛型 传统编写的限制: 在Java中一般的类和方法,只能使用具体的类型,要么是基本数据类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制就会束缚 ...

随机推荐

  1. 熔断原理与实现Golang版

    在微服务中服务间依赖非常常见,比如评论服务依赖审核服务而审核服务又依赖反垃圾服务,当评论服务调用审核服务时,审核服务又调用反垃圾服务,而这时反垃圾服务超时了,由于审核服务依赖反垃圾服务,反垃圾服务超时 ...

  2. Educational Codeforces Round 97 (Rated for Div. 2)

    补了一场Edu round. A : Marketing Scheme 水题 #include <cstdio> #include <algorithm> typedef lo ...

  3. JQuery如何实现统计图表

    EEP JQuery如何实现统计图表 讯光科技 前言 在ERP项目开发过程中,统计图表(chart)普遍应用于各种统计和报表中,其形象直观,内容清晰.EEP的JQuery网站项目使用了Easyui 插 ...

  4. 配置交换机之间直连链路聚合-LACP模式

    组网图形 LACP模式链路聚合简介 以太网链路聚合是指将多条以太网物理链路捆绑在一起成为一条逻辑链路,从而实现增加链路带宽的目的.链路聚合分为手工模式和LACP模式. LACP模式需要有链路聚合控制协 ...

  5. 走在深夜的小码农 Seventh Day

    Css3 Seventh Day writer:late at night codepeasant 学习大纲: 1. 定位(position) 介绍 1.1 为什么使用定位 我们先来看一个效果,同时思 ...

  6. CodeForces 916D Jamie and To-do List

    题意 你需要维护一个任务列表,有 \(q\) 次操作,每次操作形如以下四种: set a x:设置任务 \(a\) 的优先级为 \(x\),如果任务列表中没有 \(a\) 则加进来. remove a ...

  7. PHP 将数组转换为JSON字符串<兼容中文>

    1 /************************************************************** 2 * 3 * 使用特定function对数组中所有元素做处理 4 ...

  8. 这个蒟蒻也开通wordpress博客啦~

    RT,欢迎各位dalao常来菜鸡博客玩,加友链什么的最好了~ 传送门(请注意https不能漏,因为本菜鸡的家用宽带只有443端口). 以后博客园的博客会同步更新. 这个人太颓了,只打算在wordpre ...

  9. CopyOnWriteArrayList线程安全分析

    CopyOnWriteArrayList是开发过程中常用的一种并发容器,多用于读多写少的并发场景.但是CopyOnWriteArrayList真的能做到完全的线程安全吗? 答案是并不能. 一.Copy ...

  10. linux-挂载NFS网络文件系统教程

    目录 前言 链接 参考 笔录草稿 NFS环境搭建 前言 本文实现需要联网 链接 野火NFS介绍 NFS详细介绍 NFS简要介绍 参考 上面链接 笔录草稿 NFS环境搭建 一些目标配置 服务主机共享目录 ...