Java 8 创建 Stream 的 10 种方式,我保证你受益无穷!

简介: Java 8 创建 Stream 的 10 种方式,我保证你受益无穷!

image.pngJava技术栈


www.javastack.cn


优秀的Java技术公众号




之前栈长分享过 Java 8 一系列新特性的文章,其中重点介绍了 Stream。


image.png


获取上面这份 Java 8~12 系列新特性干货文章,请在微信搜索关注微信公众号:Java技术栈,在公众号后台回复:java。


今天来分享下在 Java 8 中创建 Stream 的 10 种方式,我就整理了 10 种,其实还有更多,仅供大家参考学习下。


1、Stream.of 可变参数

Stream<String> stream1 = Stream.of("A", "B", "C");System.out.println("stream1:" + stream1.collect(joining()));of("A", "B", "C");System.out.println("stream1:" + stream1.collect(joining()));

程序输出:

stream1:ABC

2、Stream.of 数组

String[] values = new String[]{"A", "B", "C"};Stream<String> stream2 = Stream.of(values);System.out.println("stream2:" + stream2.collect(joining()));new String[]{"A", "B", "C"};Stream<String> stream2 = Stream.of(values);System.out.println("stream2:" + stream2.collect(joining()));

程序输出:

stream2:ABC

看 Stream.of 源码,上面这两种方式其实就是第三种方式的包装版。

public static<T> Stream<T> of(T... values) {    return Arrays.stream(values);}    return Arrays.stream(values);}

我们直接使用源码中的方式也是一样的。

3、Arrays.stream

String[] values = new String[]{"A", "B", "C"};Stream<String> stream3 = Arrays.stream(values);System.out.println("stream3:" + stream3.collect(joining()));new String[]{"A", "B", "C"};Stream<String> stream3 = Arrays.stream(values);System.out.println("stream3:" + stream3.collect(joining()));

程序输出:

stream3:ABC

4、List

List<String> list = Arrays.asList("A", "B", "C");Stream<String> stream4 = list.stream();System.out.println("stream4:" + stream4.collect(joining()));list = Arrays.asList("A", "B", "C");Stream<String> stream4 = list.stream();System.out.println("stream4:" + stream4.collect(joining()));

程序输出:

stream4:ABC

5、Set

Set<String> set = new HashSet<>(Arrays.asList("A", "B", "C"));Stream<String> stream5 = set.stream();System.out.println("stream5:" + stream5.collect(joining()));String> set = new HashSet<>(Arrays.asList("A", "B", "C"));Stream<String> stream5 = set.stream();System.out.println("stream5:" + stream5.collect(joining()));

程序输出:

stream5:ABC

6、Map

Map<String, String> map = new HashMap<>();map.put("1", "A");map.put("2", "B");map.put("3", "C");Stream<String> stream6 = map.values().stream();System.out.println("stream6:" + stream6.collect(joining()));new HashMap<>();map.put("1", "A");map.put("2", "B");map.put("3", "C");Stream<String> stream6 = map.values().stream();System.out.println("stream6:" + stream6.collect(joining()));

程序输出:

stream6:ABC

7、Stream.iterate

Stream<String> stream7 = Stream.iterate("A", e -> String.valueOf((char) (e.charAt(0) + 1))).limit(3);System.out.println("stream7:" + stream7.collect(joining()));"A", e -> String.valueOf((char) (e.charAt(0) + 1))).limit(3);System.out.println("stream7:" + stream7.collect(joining()));

程序输出:

stream7:ABC

8、Pattern

String value = "A B C";Stream<String> stream8 = Pattern.compile("\\W").splitAsStream(value);System.out.println("stream8:" + stream8.collect(joining()));"A B C";Stream<String> stream8 = Pattern.compile("\\W").splitAsStream(value);System.out.println("stream8:" + stream8.collect(joining()));

程序输出:

stream8:ABC

9、Files.lines

try {    Stream<String> stream9 = Files.lines(Paths.get("d:/data.txt"));    System.out.println("stream9:" + stream9.collect(joining()));} catch (IOException e) {    e.printStackTrace();}    Stream<String> stream9 = Files.lines(Paths.get("d:/data.txt"));    System.out.println("stream9:" + stream9.collect(joining()));} catch (IOException e) {    e.printStackTrace();}

data.txt文件内容如下:

ABCBC

程序输出:

stream9:ABC

10、Stream.generate

Stream<String> stream10 = Stream.generate(() -> "A").limit(3);System.out.println("stream10:" + stream10.collect(joining()));"A").limit(3);System.out.println("stream10:" + stream10.collect(joining()));

程序输出:

stream10:AAA

好了,这是栈长整理的 10 种创建 Stream 的方式,是不是很骚?如果你还知道其他的骚操作,可以留言告诉大家,让大家记住你的头像和ID。

相关文章
|
5月前
|
安全 Java API
告别繁琐编码,拥抱Java 8新特性:Stream API与Optional类助你高效编程,成就卓越开发者!
【8月更文挑战第29天】Java 8为开发者引入了多项新特性,其中Stream API和Optional类尤其值得关注。Stream API对集合操作进行了高级抽象,支持声明式的数据处理,避免了显式循环代码的编写;而Optional类则作为非空值的容器,有效减少了空指针异常的风险。通过几个实战示例,我们展示了如何利用Stream API进行过滤与转换操作,以及如何借助Optional类安全地处理可能为null的数据,从而使代码更加简洁和健壮。
142 0
|
1月前
|
存储 Java 数据挖掘
Java 8 新特性之 Stream API:函数式编程风格的数据处理范式
Java 8 引入的 Stream API 提供了一种新的数据处理方式,支持函数式编程风格,能够高效、简洁地处理集合数据,实现过滤、映射、聚合等操作。
65 6
|
1月前
|
Java API 开发者
Java中的Lambda表达式与Stream API的协同作用
在本文中,我们将探讨Java 8引入的Lambda表达式和Stream API如何改变我们处理集合和数组的方式。Lambda表达式提供了一种简洁的方法来表达代码块,而Stream API则允许我们对数据流进行高级操作,如过滤、映射和归约。通过结合使用这两种技术,我们可以以声明式的方式编写更简洁、更易于理解和维护的代码。本文将介绍Lambda表达式和Stream API的基本概念,并通过示例展示它们在实际项目中的应用。
|
30天前
|
Rust 安全 Java
Java Stream 使用指南
本文介绍了Java中Stream流的使用方法,包括如何创建Stream流、中间操作(如map、filter、sorted等)和终结操作(如collect、forEach等)。此外,还讲解了并行流的概念及其可能带来的线程安全问题,并给出了示例代码。
|
2月前
|
安全 Java API
Java中的Lambda表达式与Stream API的高效结合####
探索Java编程中Lambda表达式与Stream API如何携手并进,提升数据处理效率,实现代码简洁性与功能性的双重飞跃。 ####
33 0
|
3月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
56 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
3月前
|
Java Shell 流计算
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
33 1
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
|
2月前
|
Java API 数据处理
探索Java中的Lambda表达式与Stream API
【10月更文挑战第22天】 在Java编程中,Lambda表达式和Stream API是两个强大的功能,它们极大地简化了代码的编写和提高了开发效率。本文将深入探讨这两个概念的基本用法、优势以及在实际项目中的应用案例,帮助读者更好地理解和运用这些现代Java特性。
|
4月前
|
存储 Java API
Java——Stream流详解
Stream流是JDK 8引入的概念,用于高效处理集合或数组数据。其API支持声明式编程,操作分为中间操作和终端操作。中间操作包括过滤、映射、排序等,可链式调用;终端操作则完成数据处理,如遍历、收集等。Stream流简化了集合与数组的操作,提升了代码的简洁性
209 11
|
4月前
|
Java API C++
Java 8 Stream Api 中的 peek 操作
本文介绍了Java中`Stream`的`peek`操作,该操作通过`Consumer&lt;T&gt;`函数消费流中的每个元素,但不改变元素类型。文章详细解释了`Consumer&lt;T&gt;`接口及其使用场景,并通过示例代码展示了`peek`操作的应用。此外,还对比了`peek`与`map`的区别,帮助读者更好地理解这两种操作的不同用途。作者为码农小胖哥,原文发布于稀土掘金。
161 9
Java 8 Stream Api 中的 peek 操作