欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

详解JAVA Stream流

时间:2021-02-09 14:32:40|栏目:JAVA代码|点击:

摘要

  • 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));

上一篇:Spring MVC之@RequestMapping注解详解

栏    目:JAVA代码

下一篇:浅谈 JDBC 元数据

本文标题:详解JAVA Stream流

本文地址:http://www.codeinn.net/misctech/59752.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有