Java8实战之Stream流式操作

简介
Java8中有两大最为重要的改变。第一个是Lambda 表达式;另外一个则是Stream API(java.util.stream.*)。
Stream 是Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。使用Stream API 对集合数据进行操作,就类似于使用SQL 执行的数据库查询。也可以使用Stream API来并行执行操作。简而言之,Stream API提供了一种高效且易于使用的处理数据的方式。

Stream(流)是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。“集合讲的是数据,流讲的是计算!”

注意:
1.Stream 自己不会存储元素。
2. Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。
3. Stream操作是延迟执行的。这意味着他们会等到需要结果的时候才执行

Stream操作步骤
创建Stream:一个数据源(如:集合、数组),获取一个流
中间操作:一个中间操作链,对数据源的数据进行处理
终止操作(终端操作):一个终止操作,执行中间操作链,并产生结果
流程如下图所示:


创建Stream
方式一:Java8 中的Collection 接口被扩展,提供了两个获取流的方法:

default Stream<E> stream(): 返回一个顺序流
default Stream<E> parallelStream() : 返回一个并行流
// 1、 通过Collection集合提供的stream()或parallelStream()
List<String> list = new ArrayList<>();
// stream()
Stream<String> stream1 = list.stream();
// parallelStream()
Stream<String> parallelStream = list.parallelStream();


方式二:通过Arrays中的静态方法stream()获取数组流

// 2、通过Arrays中的静态方法stream()获取数组流
String[] strArray = {"1","2"};
Stream<String> stream2 = Arrays.stream(strArray);


方式三:通过stream类中的静态方法of(),它可以接收任意数量的参数

// 通过stream类中的静态方法of()
Stream<String> stream3 = Stream.of("1", "2");


方式四:创建无限流,可以使用静态方法Stream.iterate() 和Stream.generate(), 创建无限流

// 4、创建无限流
// 使用迭代
Stream<Integer> iterateStream = Stream.iterate(0, (e) -> e + 2);
iterateStream.limit(10).forEach(System.out::println);

// 使用生成
Stream<Double> generateStream = Stream.generate(() -> Math.random());
generateStream.limit(10).forEach(System.out::println);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值