详解JAVA Stream流

摘要

  • Stream 是对集合对象功能的增强,它专注于对集合对象进行各种非常便利、高效的聚合操作,或者大批量数据操作。通常我们需要多行代码才能完成的操作,借助于Stream流式处理可以很简单的实现。
  • Stream 不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的。

创建Steam流

  • 调用Collection.stream()函数创建一个Stream对象
  • Stream 接口的静态方法 of 可以获取数组对应的流
List<String> list = new ArrayList<>();
Stream<String> stream1 = list.stream();

String[] arr = {"张三", "李四", "王五"};
Stream<String> stream2 = Stream.of(arr);

常用方法

  • void forEach(Consumer<? super T> action):该方法接收一个Consumer接口函数,会将每一个流元素交给该函数进行处理。此方法为终结方法,遍历后不能再调用Stream流的其他方法。

Consumer<T>函数式接口是一个消费型接口。 Consumer接口中包含抽象方法void accept(T t),意为消费一个指定泛型的数据。

import java.util.stream.Stream;

public class Start {
  public static void main(String[] args) {
    String[] arr = {"张三", "李四", "王五"};
    Stream<String> stream2 = Stream.of(arr);

    stream2.forEach((name)->{
      System.out.println(name);
    });
  }
}
  • Stream<T> filter(Predicate<? super T> predicate) :将一个流转换成另一个子集流,此方法为终结方法。

Predicate<T>函数式接口,抽象方法boolean test(T t)用来对指定数据进行判断是否满足条件。

import java.util.stream.Stream;

public class Start {
  public static void main(String[] args) {
    //获取Stream流
    String[] arr = {"张三", "李四", "王五"};
    Stream<String> stream2 = Stream.of(arr);

    //filter方法
    Stream<String> fil = stream2.filter((name) -> {
      return name.startsWith("张");
    });
    fil.forEach(name->System.out.println(name));
  }
}
  • Stream<R> map(Function<? super T, ? extends R> mapper):将流中的元素映射到另一个流中。

Function<T>函数式接口,可以将当前流中的T类型数据转换为另一种R类型的流。

import java.util.stream.Stream;

public class Start {
  public static void main(String[] args) {
    //获取Stream流
    String[] arr = {"1", "2", "3"};
    Stream<String> stream2 = Stream.of(arr);

    //map方法
    Stream<Integer> map = stream2.map((string) -> {
      return Integer.parseInt(string);
    });
    map.forEach(integer->System.out.println(integer));
  }
}
  • long count() :统计流中元素的个数,此方法为终结方法。
  • Stream<T> limit(long n):用于截取流中的元素,只取用前n个元素,此方法是延迟方法,可以继续调用Stream流中的其他方法。

stream1.limit(2).forEach(name -> System.out.println(name));

  • Stream<T> skip(long n):用于跳过流中的元素,跳过n个元素,获取剩下的元素组成新流,此方法是延迟方法。

stream1.skip(1).forEach(name -> System.out.println(name));

  • static <T> Stream<T> concat(Stream<? extends T> a, Stream<? extends T> b):Stream的静态方法,将两个流合并为一个流。

Stream.concat(stream1, stream2).forEach(string -> System.out.println(string));

以上就是详解JAVA Stream流的详细内容,更多关于JAVA Stream流的资料请关注我们其它相关文章!

(0)

相关推荐

  • Java中FileOutputStream流的write方法

    本文为大家分享了FileOutputStream流的write方法,供大家参考,具体内容如下 /*------------------------ FileOutputStream: ....//输出流,字节流 ....//write(byte[] b)方法: 将b.length个字节从指定字节数组写入此文件输出流中 ....//write(byte[] b, int off, int len)方法:将指定字节数组中从偏移量off开始的len个字节写入此文件输出流 ---------------

  • 举例讲解Java中的Stream流概念

    1.基本的输入流和输出流 流是 Java 中最重要的基本概念之一.文件读写.网络收发.进程通信,几乎所有需要输入输出的地方,都要用到流. 流是做什么用的呢?就是做输入输出用的.为什么输入输出要用"流"这种方式呢?因为程序输入输出的基本单位是字节,输入就是获取一串字节,输出就是发送一串字节.但是很多情况下,程序不可能接收所有的字节之后再进行处理,而是接收一点处理一点.比方你下载魔兽世界,不可能全部下载到内存里再保存到硬盘上,而是下载一点就保存一点.这时,流这种方式就非常适合. 在 Jav

  • 简单总结Java IO中stream流的使用方法

    Java语言的输入输出功能是十分强大而灵活的,对于数据的输入和输出操作以"流"(stream)的方式进行.J2SDK提供了各种各样的"流"类,用以获取不同种类的数据,定义在包java.io中.程序中通过标准的方法输入或输出数据. Java中的流可以从不同的角度进行分类: 按照流的方向不同:分为输入流和输出流. 按照处理数据单位的不同:分为字节流(8位)和字符流(16位). 按照功能不同:分为节点流和处理流. 节点流:是可以从一个特定的数据源(节点)读写数据的流(例如

  • Java中的stream流的概念解析及实际运用总结

    流是字节序列的抽象概念. 文件是数据的静态存储形式,而流是指数据传输时的形态. 流类分为两个大类:节点流类和过滤流类(也叫处理流类). 程序用于直接操作目标设备所对应的类叫节点流类,程序也可以通过一个间接流类去调用节点流类,以达到更加灵活方便地读取各种类型的数据,这个间接流类就是过滤流类(也叫处理流类),或者称为包装类. 包装类的调用过程如下图: 流分类的关系 不管流的分类是多么的丰富和复杂,其根源来自于四个基本的类.这个四个类的关系如下: 字节流 字符流 输入流 InputStream Rea

  • Java使用FileInputStream流读取文件示例详解

    一.File流概念 JAVA中针对文件的读写操作设置了一系列的流,其中主要有FileInputStream,FileOutputStream,FileReader,FileWriter四种最为常用的流 二.FileInputStream 1)FileInputStream概念  FileInputStream流被称为文件字节输入流,意思指对文件数据以字节的形式进行读取操作如读取图片视频等 2)构造方法 2.1)通过打开与File类对象代表的实际文件的链接来创建FileInputStream流对象

  • Java8新特性Stream流实例详解

    什么是Stream流? Stream流是数据渠道,用于操作数据源(集合.数组等)所生成的元素序列. Stream的优点:声明性,可复合,可并行.这三个特性使得stream操作更简洁,更灵活,更高效. Stream的操作有两个特点:可以多个操作链接起来运行,内部迭代. Stream可分为并行流与串行流,Stream API 可以声明性地通过 parallel() 与sequential() 在并行流与顺序流之间进行切换.串行流就不必再细说了,并行流主要是为了为了适应目前多核机器的时代,提高系统CP

  • BufferedInputStream(缓冲输入流)详解_动力节点Java学院整理

    BufferedInputStream 介绍 BufferedInputStream 是缓冲输入流.它继承于FilterInputStream. BufferedInputStream 的作用是为另一个输入流添加一些功能,例如,提供"缓冲功能"以及支持"mark()标记"和"reset()重置方法". BufferedInputStream 本质上是通过一个内部缓冲区数组实现的.例如,在新建某输入流对应的BufferedInputStream后,

  • Java实现inputstream流的复制代码实例

    这篇文章主要介绍了Java实现inputstream流的复制代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 获取到一个inputstream后,可能要多次利用它进行read的操作.由于流读过一次就不能再读了,而InputStream对象本身不能复制,而且它也没有实现Cloneable接口,所以得想点办法. 实现思路: 1.先把InputStream转化成ByteArrayOutputStream 2.后面要使用InputStream对象

  • Java8中的Stream流式操作教程之王者归来

    前言 相对于Java8之前的Java的相关操作简直是天差地别,Java8 的流式操作的出现,也很大程度上改变了开发者对于Java的繁琐的操作的印象,从此,Java也走向了函数式编程的道路! 1 流的创建 1.1 流的创建方法 既然需要聊聊流的操作,那么,首先还是先看看怎么创建流. 创建流的方法有三种,分别是:Stream.of().Stream.iterate().Stream.generate(),然后,分别看一下这三个方法的声明. static <T> Stream<T> of

  • java8 Stream流逐行处理文本文件

    本文中为大家介绍使用java8 Stream API逐行读取文件,以及根据某些条件过滤文件内容 1. Java 8逐行读取文件 在此示例中,我将按行读取文件内容并在控制台打印输出. Path filePath = Paths.get("c:/temp", "data.txt"); //try-with-resources语法,不用手动的编码关闭流 try (Stream<String> lines = Files.lines( filePath )) {

  • Java的DataInputStream和DataOutputStream数据输入输出流

    DataInputStream  DataInputStream 是数据输入流.它继承于FilterInputStream. DataInputStream 是用来装饰其它输入流,它"允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型".应用程序可以使用DataOutputStream(数据输出流)写入由DataInputStream(数据输入流)读取的数据. DataInputStream 函数列表: DataInputStream(InputStream in)

随机推荐