285. Java Stream API - 通过 Supplier 创建 Stream

文章目录

  • [285. Java Stream API - 通过 Supplier 创建 Stream](#285. Java Stream API - 通过 Supplier 创建 Stream)
      • [✅ 基本概念](#✅ 基本概念)
      • [🧪 示例代码](#🧪 示例代码)
        • [💻 输出结果:](#💻 输出结果:)
      • [⚠️ 小心!这是个无限流!](#⚠️ 小心!这是个无限流!)
      • [🎯 正确使用方式:结合 **限制操作(short-circuiting)**](#🎯 正确使用方式:结合 限制操作(short-circuiting))
      • [🧠 学习要点](#🧠 学习要点)
      • [📌 示例:生成时间戳](#📌 示例:生成时间戳)
      • [🧪 小练习题(可做培训互动)](#🧪 小练习题(可做培训互动))
      • [📚 小结](#📚 小结)

285. Java Stream API - 通过 Supplier 创建 Stream


✅ 基本概念

JavaStream 接口提供了两个用于从 Supplier(供应者) 创建流的工厂方法,其中之一就是:

java 复制代码
Stream.generate(Supplier<T> supplier)

这个方法用于 生成无限流(infinite stream) :每当流需要一个新元素时,Supplier 就会被调用一次来"供应"这个元素。


🧪 示例代码

java 复制代码
Stream<String> generated = Stream.generate(() -> "+");
List<String> strings = generated.limit(5L).toList();
System.out.println("strings = " + strings);
💻 输出结果:
java 复制代码
strings = [+, +, +, +, +]

⚠️ 小心!这是个无限流!

❗ 如果你去掉 .limit(5L),这个程序将永远不会停止运行!

java 复制代码
Stream<String> generated = Stream.generate(() -> "+");
generated.forEach(System.out::println); // ❌ 小心,死循环

🚨 它将不停地生成 +,直到你的内存耗尽,甚至抛出 OutOfMemoryError


🎯 正确使用方式:结合 限制操作(short-circuiting)

Stream API 中,像 limit() 这样的操作被称为 短路操作(short-circuiting operations)。它的作用是"提前终止流的生成或处理"。

✅ 加上 limit(n),我们就可以从无限流中"截取"前 n 个元素使用。

java 复制代码
Stream<Double> randoms = Stream.generate(Math::random);
List<Double> topFive = randoms.limit(5).toList();
System.out.println(topFive); // 打印 5 个随机数

🧠 学习要点

关键点 说明
Stream.generate(...) 会创建一个 无限 的流
必须 使用 limit() 或其他短路操作 否则程序会永远运行或耗尽资源
适合生成固定模式、常量、随机数等 比如 "++++++++" 或随机数序列
每次调用都会重新获取一个值 这与 of(...)Arrays.stream(...)静态集合 不同

📌 示例:生成时间戳

java 复制代码
Stream<String> timeStream = Stream.generate(() -> Instant.now().toString());
List<String> timestamps = timeStream.limit(3).toList();
System.out.println(timestamps);

输出三个不同时间戳,适合用于日志采样、延迟任务等场景。


🧪 小练习题(可做培训互动)

问:以下代码会输出几个 "Hello"

java 复制代码
Stream.generate(() -> "Hello")
      .limit(3)
      .forEach(System.out::println);

答案:

java 复制代码
Hello
Hello
Hello

📚 小结

  • Stream.generate(...) = 无限供应机,每次都生产一个元素。
  • 不加限制操作就是"失控的水龙头 💦",必须加上 .limit().takeWhile() 等手段节流。
  • 适合用于生成常量、重复元素、随机值、当前时间等"动态"数据。
相关推荐
还在忙碌的吴小二5 分钟前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring
风吹迎面入袖凉6 分钟前
【Redis】Redis的五种核心数据类型详解
java·redis
liliangcsdn6 分钟前
mstsc不在“C:\Windows\System32“下在C:\windows\WinSxS\anmd64xxx“问题分析
开发语言·windows
夕除13 分钟前
javaweb--02
java·tomcat
小陈工17 分钟前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
ailvyuanj18 分钟前
2026年Java AI开发实战:Spring AI完全指南
java
KAU的云实验台20 分钟前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆26 分钟前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
张np31 分钟前
java进阶-Dubbo
java·dubbo
汽车仪器仪表相关领域32 分钟前
NHFID-1000型非甲烷总烃分析仪:技术破局,重构固定污染源监测新体验
java·大数据·网络·人工智能·单元测试·可用性测试·安全性测试