Java 8 Stream

本文介绍 Java 8 中新增的 Stream API,它允许开发者以声明式方式处理数据,提供类似 SQL 的操作来简化集合处理。文章涵盖了 Stream 的生成、特性如 Pipelining 和内部迭代,以及常见操作如 filter、map 和 reduce 的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Java 8 Stream

Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据 , Stream 使用一种类似用 SQL 语句从数据库查询数据的直观方式来提供一种对 Java 集合运算和表达的高阶抽象。
这种风格将要处理的元素集合看作一种流, 流在管道中传输, 并且可以在管道的节点上进行处理, 比如筛选, 排序,聚合等

2、流是什么

Stream(流)是一个来自数据源的元素队列并支持聚合操作
- 数据源 流的来源: 可以是集合,数组,I/O channel, 产生器generator 等
-聚合操作: 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
和以前的Collection操作不同, Stream操作还有两个基础的特征。

*两个特征:*

-Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
-内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。

3、生成流

stream() − 为集合创建串行流。
parallelStream() − 为集合创建并行流。

4、 stream()

> *filter:* 对于Stream中包含的元素使用给定的过滤函数进行过滤操作,新生成的Stream只包含符合条件的元素;
这里写图片描述

代码片段

List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");

        /**
         * 通过流过滤数组中不为空的字符串
         */
        // List<String> 转为流Stream<String>
        Stream<String> stringsStream = strings.stream();
        // 调用filter 过滤不为空的
        stringsStream = stringsStream.filter(string -> !string.isEmpty());
        //collect()方法的参数则被用来指定如何进行聚集操作。在这里我们使用toList()以把元素输出到List中
        strings = stringsStream.collect(Collectors.toList());
        System.out.println("输出不为空的字符串=" + strings.toString());

> map
map 方法用于映射每个元素到对应的结果,这里写图片描述

distinct: 对于Stream中包含的元素进行去重操作(去重逻辑依赖元素的equals方法),新生成的Stream中没有重复的元素;这里写图片描述

代码片段:

        List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
        stringsStream = strings.stream();
        stringsStream = stringsStream.filter(string -> !string.isEmpty());
        stringsStream =stringsStream.map(string->string.toUpperCase());
        stringsStream.distinct();

forEach

Stream 提供了新的方法 ‘forEach’ 来迭代流中的每个数据

代码片段

        List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
        stringsStream = strings.stream();
        stringsStream = stringsStream.filter(string -> !string.isEmpty());

        System.out.println("转成大写后的字符串:");
        stringsStream.forEach(action->{
            action =action.toUpperCase();
            System.out.println(" "+action);
        });

limit

对一个Stream进行截断操作,获取其前N个元素,如果原Stream中包含的元素个数小于N,那就获取其所有的元素;这里写图片描述

代码片段

 strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
 stringsStream = strings.stream();
        stringsStream = stringsStream.limit(3);
        strings = stringsStream.collect(Collectors.toList());

flatMap

flatMap 把 Stream 中的层级结构扁平化,就是将最底层元素抽出来放到一起,最终输出的新 Stream , 就是把 将小流合并成一个大流

{{1,2}{3,4}{5,6}}  - > flatMap  - > {1,2,3,4,5,6}

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值