目录
写在前面
前面我们讲了Java8的新特性Lambda表达式,我们用了五篇文章讲解了如何使用Lambda表达式以及Lambda表达式的延伸,比如方法引用和构造器引用。
现在我们来讲一下Java8的另一个新特性stream api。
了解Stream
Java8中有两大最为重要的改变。第一个是 Lambda 表达式;另外一 个则是
Stream API(java.util.stream.*)。 Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对 集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。 使用Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数 据库查询。也可以使用 Stream API 来并行执行操作。简而言之, Stream API 提供了一种高效且易于使用的处理数据的方式。
什么是Stream
是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。
“集合讲的是数据,流讲的是计算!”
注意:
①Stream 自己不会存储元素。
②Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。
③Stream 操作是延迟执行的。这意味着他们会等到需要结果的时候才执行。
Stream 的操作三个步骤
⚫ 创建 Stream(这篇文章的重点)
一个数据源(如:集合、数组),获取一个流
⚫ 中间操作
一个中间操作链,对数据源的数据进行处理
⚫ 终止操作(终端操作)
一个终止操作,执行中间操作链,并产生结果
创建Stream(这篇文章的重点)
创建流的四种方法
代码
package com.csdn.test;
import org.junit.Test;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.stream.IntStream;
import java.util.stream.Stream;
/**
* @author summer
* @date 2022-04-16 13:01
*/
public class TestStream1 {
/**
* Java8 中的 Collection 接口被扩展,提供了
* 两个获取流的方法:
* default Stream<E> stream() : 返回一个顺序流
* default Stream<E> parallelStream() : 返回一个并行流
*/
@Test
public void test1(){
List<String> list = Arrays.asList("abc","def","bac");
Stream<String> stream = list.stream();
Stream<String> stringStream = list.parallelStream();
}
/**
* Java8 中的 Arrays 的静态方法 stream() 可
* 以获取数组流:
* static <T> Stream<T> stream(T[] array): 返回一个流
*/
@Test
public void test(){
int[] a = {1,2,3,4,5};
IntStream stream = Arrays.stream(a);
String[] str = {"a","b","c"};
Stream<String> stream1 = Arrays.stream(str);
}
/**
* 可以使用静态方法 Stream.of(), 通过显示值
* 创建一个流。它可以接收任意数量的参数。
*/
@Test
public void test3(){
int[] a = {1,2,3,4,5};
Stream<int[]> a1 = Stream.of(a);
List<String> list = Arrays.asList("abc","def","bac");
Stream<List<String>> listStream = Stream.of(list);
}
/**
* 可以使用静态方法 Stream.iterate() 和
* Stream.generate(), 创建无限流。
*/
@Test
public void test4(){
Stream<Integer> integerStream = Stream.iterate(0, x -> x + 2);
Stream<Date> dateStream = Stream.generate(() -> new Date());
}
}