steam流式JAVA_详解JAVA Stream流

摘要

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

Stream 不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的。

创建Steam流

调用Collection.stream()函数创建一个Stream对象

Stream 接口的静态方法 of 可以获取数组对应的流

List list = new ArrayList<>();

Stream stream1 = list.stream();

String[] arr = {"张三", "李四", "王五"};

Stream stream2 = Stream.of(arr);

常用方法

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

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

import java.util.stream.Stream;

public class Start {

public static void main(String[] args) {

String[] arr = {"张三", "李四", "王五"};

Stream stream2 = Stream.of(arr);

stream2.forEach((name)->{

System.out.println(name);

});

}

}

Stream filter(Predicate super T> predicate) :将一个流转换成另一个子集流,此方法为终结方法。

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

import java.util.stream.Stream;

public class Start {

public static void main(String[] args) {

//获取Stream流

String[] arr = {"张三", "李四", "王五"};

Stream stream2 = Stream.of(arr);

//filter方法

Stream fil = stream2.filter((name) -> {

return name.startsWith("张");

});

fil.forEach(name->System.out.println(name));

}

}

Stream map(Function super T, ? extends R> mapper):将流中的元素映射到另一个流中。

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

import java.util.stream.Stream;

public class Start {

public static void main(String[] args) {

//获取Stream流

String[] arr = {"1", "2", "3"};

Stream stream2 = Stream.of(arr);

//map方法

Stream map = stream2.map((string) -> {

return Integer.parseInt(string);

});

map.forEach(integer->System.out.println(integer));

}

}

long count():统计流中元素的个数,此方法为终结方法。

Stream limit(long n):用于截取流中的元素,只取用前n个元素,此方法是延迟方法,可以继续调用Stream流中的其他方法。

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

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

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

static Stream 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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值