- Hands-On Reactive Programming in Spring 5
- Oleh Dokuka Igor Lozynskyi
- 332字
- 2021-07-23 16:36:32
Mono
Now, let's look at how the Mono type is different from the Flux type:
In contrast with Flux, the Mono type defines a stream that can produce at most one element and can be described by the following formula:
onNext x 0..1 [onError | onComplete]
The distinction between Flux and Mono allows us to not only introduce additional meaning to the method signatures, but also enables more efficient internal implementation of Mono due to skipping redundant buffers and costly synchronizations.
Mono<T> may be useful in cases when an application API returns one element at most. Consequently, it can easily replace CompletableFuture<T>, giving a pretty similar semantic. Of course, these two types have some small semantic differences—CompletableFuture, unlike Mono, cannot complete normally without emitting a value. Also, CompletableFuture starts processing immediately, while Mono does nothing until a subscriber appears. The benefit of the Mono type lies in providing plenty of reactive operators and the ability to be flawlessly incorporated into a bigger reactive workflow.
Also, Mono can be used when it is required to notify a client about a finished action. In such cases, we may return the Mono<Void> type and signal onComplete() when processing is done or onError() in the event of failure. In such a scenario, we don't return any data but signal a notification, which in turn may be used as a trigger for further computation.
Mono and Flux are not detached types and can easily be "transformed" into each other. For example, Flux<T>.collectList() returns Mono<List<T>> and Mono<T>.flux() returns Flux<T>. In addition, the library is smart enough to optimize some transformations that do not change the semantic. For example, let's consider the following transformation (Mono -> Flux -> Mono):
Mono.from(Flux.from(mono))
When calling the preceding code, it returns the original mono instance, as this is conceptually a no-ops conversion.
- 解析QUIC/HTTP3:未來互聯網的基石
- 網絡協議工程
- 物聯網安全(原書第2版)
- 物聯網安全與深度學習技術
- JBoss EAP6 High Availability
- Web Application Development with R Using Shiny
- 局域網組建、管理與維護項目教程(Windows Server 2003)
- 企業私有云建設指南
- 數字通信同步技術的MATLAB與FPGA實現:Altera/Verilog版(第2版)
- 區塊鏈輕松上手:原理、源碼、搭建與應用
- 中國互聯網發展報告2018
- 新手易學:新手學淘寶開店
- 網管工具使用與技巧大全
- 語音信號處理及Blackfin DSP實現
- Android UI Design