Java 8 Stream

什么是 Stream?

Stream 是Java8的新特性,它允许你以声明式的方式处理数据集合,可以把 它看作是遍历数据集的高级迭代器。此外与stream与lambada表达示结合后 编码效率与大大提高,并且可读性更强。

要澄清的是java8中的stream与InputStream和OutputStream是完全 不同的概念

简单案例:

 public static void main(String[] args) {
 List<Apple> applestore = new ArrayList();
 applestore.add(new Apple(1,"red",500,"河南"));
 applestore.add(new Apple(2,"red",400,"陕西"));
 applestore.add(new Apple(3,"green",300,"上海"));
 applestore.add(new Apple(4,"green",200,"湖北"));
 applestore.add(new Apple(5,"green",100,"湖南"));
 }

我们的需求是在applestore 集合中找出红色苹果手机. 使用Stream流快速实现操作

List<Apple> apples = applestore
 .stream()
 .filter(a-> a.getColor().equals("red"))
 .collect(Collectors.toList());

这里使用的就是Java8中的stream流,使用的是声明性方式写的:说明想 要完成什么(筛选,排序,取值),而不说明如何实现一个操作(for 循环)。 同时可以将这些操作链接起来,达到一种流水线式的效果:

Java8 中的集合支持一个新的Stream方法,它会返回一个流

什么是流呢?

简单的定义,就是“从支持数据处理操作的源,生成的元素序列”。

元素列表:和集合一样,流也提供了一个接口,访问特定元素类型的一组有序值。

数据源:获取数据的源,比如集合。

数据处理操作:流更偏向于数据处理和计算,比如filter、map、find、sort等。

简单来说,我们通过一个集合的stream方法获取一个流,然后对流进行一 系列流操作,最后再构建成我们需要的数据集合。

语法:

 stream of elements +-----> |filter+-> |sorted+-> |map+-> |collect|+
 List<Integer> list =
 widgets.stream()
 .filter(b-> b.getColor() == RED)
 .sum();

获取流

使用Collection 接口下的 stream()

 List<String> list = new ArrayList<>();
 Stream<String> stream = list.stream();

使用Arrays 中的 stream() 方法,将数组转成流

Integer[] nums = new Integer[10];
 Stream<Integer> stream = Arrays.stream(nums);

使用Stream中的静态方法:of()

 Stream<Integer> stream = Stream.of(1,2,3,4,5,6);

使用 BufferedReader.lines() 方法,将每行内容转成流

BufferedReader reader=new BufferedReader(new FileReader("stream.txt"));
 Stream<String> lineStream = reader.lines();

流操作

流操作可以分为两类:中间操作和终端操作。回看之前的代码

简化一下就是: 数据源 => 中间操作 => 终端操作 => 结果

诸如filter 或者sort等中间操作会返回另一个流,进而进行下一步流操作,而终 端操作则是将流关闭,构建新的数据集合对象(也可以不构建)。

中间操作

filter:过滤流中的某些元素,

sorted(): 自然排序,流中元素需实现Comparable接口

distinct: 去除重复元素

limit(n): 获取 n 个元素

skip(n): 跳过 n 元素,配合limit(n)可实现分页

map(): 将其映射成一个新的元素

终端操作

forEach: 遍历流中的元素

toArray:将流中的元素倒入一个数组 Min:返回流中元素最小值

Max:返回流中元素最大值 count:返回流中元素的总个数

Reduce:所有元素求和

anyMatch:接收一个 Predicate 函数,只要流中有一个元素满足条件则返 回true,否则返回false

allMatch:接收一个 Predicate 函数,当流中每个元素都符合条件时才返 回true,否则返回false

findFirst:返回流中第一个元素 collect:将流中的元素倒入一个集合,Collection或Map

  • 19
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 8引入了Stream API,它是一种处理集合数据的新方式。Stream API提供了一种流式操作的方式,可以对集合进行过滤、映射、排序、聚合等操作,使得代码更加简洁、易读和高效。 Stream是一个来自数据源的元素队列并支持聚合操作。它可以是集合、数组、I/O channel、产生器等。Stream操作可以顺序执行,也可以并行执行。 Java 8 Stream API的特点包括: 1. 延迟执行:Stream操作通常是延迟执行的,只有在终止操作时才会触发实际的计算。 2. 内部迭代:Stream API使用内部迭代的方式,不需要显式地编写循环,使得代码更加简洁。 3. 函数式编程:Stream API支持函数式编程风格,可以通过Lambda表达式来定义操作。 4. 并行处理:Stream API提供了并行处理的能力,可以充分利用多核处理器的优势,提高处理速度。 使用Stream API可以通过一系列的中间操作和终止操作来对集合进行处理。中间操作包括过滤、映射、排序等操作,终止操作包括聚合、收集、遍历等操作。 下面是一些常用的Stream操作方法: 1. filter(Predicate<T> predicate):根据指定条件过滤元素。 2. map(Function<T, R> mapper):将元素进行映射转换。 3. sorted(Comparator<T> comparator):对元素进行排序。 4. distinct():去除重复的元素。 5. limit(long maxSize):限制元素的数量。 6. skip(long n):跳过指定数量的元素。 7. forEach(Consumer<T> action):对每个元素执行指定操作。 8. collect(Collector<T, A, R> collector):将元素收集到集合中。 9. reduce(BinaryOperator<T> accumulator):对元素进行归约操作。 10. parallel():启用并行处理。 以上只是Stream API的一部分常用操作,还有更多的操作方法可以根据具体需求使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值