Spring Flux方法总结

Flux 的方法非常多(几百个),但你不需要全部记住。我们可以把它们按照"功能"分成几类,就像厨房里不同的工具:

1. 制造水源(创建操作符)

用来定义流量的来源。

  • just(T... data) :最直接的,把现成的数据塞进去。
  • fromIterable(Iterable) :把 ListSet 变成 Flux
  • range(int start, int count) :生成一个整数序列(如 1 到 100)。
  • interval(Duration)定时器。每隔一段时间发一个数字(0, 1, 2...),常用于心跳检测。
  • empty() :直接发送完成信号,水管里啥也没有。
  • error(Throwable) :直接发送错误信号,水管一通就爆。

2. 加工转换(转化操作符)

最常用的部分,用来改变流里的数据。

  • map(Function)1对1转换 。把 A 变成 B(如:把"洗洁精"字符串变成 Soap 对象)。

  • flatMap(Function)1对N转换(异步) 。把一个元素变成一个新的 Flux

    比喻:map 是把菜切碎;flatMap 是把一个订单拆成多个物流单,并异步去查每一个物流。

  • buffer(int n)打包 。把零散的水滴收集满 n 个,凑成一个 List 再往下流。

  • collectList() :把水管里所有的水都接住,最后装进一个 Mono<List<T>>


3. 过滤与挑选(过滤操作符)

决定哪些东西能流过去。

  • filter(Predicate) :符合条件的才让过。
  • distinct()去重。流过的东西如果重复,只放行第一个。
  • take(long n)只取前 n 个。拿完就关水龙头。
  • skip(long n) :跳过前 n 个,从后面开始接。

4. 组合流(组合操作符)

把多根水管拼在一起。

  • mergeWith(Publisher)合并。两根管子汇成一根,谁有水谁先流(交错输出)。

  • zipWith(Publisher)配对。左边流出一滴,右边流出一滴,凑成一对(Tuple)再往下走。

    比喻:merge 是合流,zip 是相亲,必须两边都有人才成对。

  • concatWith(Publisher)首尾相接。等第一根管子流完了,才开始流第二根。


5. 副作用与生命周期(监听操作符)

只观察,不干预。

  • doOnNext(Consumer) :数据流过时看一眼(打日志)。
  • doOnError(Consumer) :出故障时看一眼。
  • doOnComplete(Runnable) :流完时看一眼。
  • doFinally(Consumer) :管它成功还是失败,最后都要执行(类似 finally 块)。

6. 错误处理(容错操作符)

水管爆了之后的救场方案。

  • onErrorReturn(T) :出错了?别报警,直接返回一个默认值。
  • onErrorResume(Function) :出错了?切到备用水管(另一个 Flux)。
  • retry(long n) :出错了?再试 n 次。

总结

  • 如果你要改变 数据:找 map/flatMap
  • 如果你要减少 数据:找 filter/take
  • 如果你要合并 数据:找 zip/merge
  • 如果你要观察 数据:找 doOn... 系列。
相关推荐
代码丰7 小时前
一文讲清楚: SSE、WebSocket 与 HTTP的关系
后端
代码丰7 小时前
java 21虚拟线程vs传统线程 原理分析以及具体测试例子去分析性能提升
后端
用户0534369380737 小时前
langchainrust:Rust 版 LangChain 框架(LLM+Agent+RAG)
后端
fox_lht8 小时前
第十章 通用集合
开发语言·后端·算法·rust
悟空聊架构8 小时前
GStack的26种专家角色,真正实现一人成军!
后端
counting money8 小时前
Spring框架基础(依赖注入-半注解形式)
java·后端·spring
Code_Artist8 小时前
一天之内我让 AI 用 Netty 造了一个最小可用的 MVC 框架:体验一下造轮子的快感😅!
后端·netty·ai编程
也许明天y8 小时前
LangChain4j + Spring Boot 多智能体协调架构原理深度解析
spring boot·后端·agent
AI人工智能+电脑小能手9 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index