成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

我對響應式編程中Mono和Flux的理解

開發(fā) 后端
很多同學反映對響應式編程中的Flux和Mono這兩個Reactor中的概念有點懵逼。但是目前Java響應式編程中我們對這兩個對象的接觸又最多,諸如Spring WebFlux、RSocket、R2DBC。

[[339894]]

1. 前言

很多同學反映對響應式編程中的Flux和Mono這兩個Reactor中的概念有點懵逼。但是目前Java響應式編程中我們對這兩個對象的接觸又最多,諸如Spring WebFlux、RSocket、R2DBC。我開始也對這兩個對象頭疼,所以今天我們就簡單來探討一下它們。

2. 響應流的特點

要搞清楚這兩個概念,必須說一下響應流規(guī)范。它是響應式編程的基石。他具有以下特點:

  • 響應流必須是無阻塞的。
  • 響應流必須是一個數(shù)據(jù)流。
  • 它必須可以異步執(zhí)行。
  • 并且它也應該能夠處理背壓。

背壓是反應流中的一個重要概念,可以理解為,生產(chǎn)者可以感受到消費者反饋的消費壓力,并根據(jù)壓力進行動態(tài)調整生產(chǎn)速率。形象點可以按照下面理解:

[[339895]]

有沒有背壓的兩種情形

 

3. Publisher

由于響應流的特點,我們不能再返回一個簡單的POJO對象來表示結果了。必須返回一個類似Java中的Future的概念,在有結果可用時通知消費者進行消費響應。

Reactive Stream規(guī)范中這種被定義為Publisher ,Publisher是一個可以提供 0-N 個序列元素的提供者,并根據(jù)其訂閱者Subscriber的需求推送元素。一個Publisher可以支持多個訂閱者,并可以根據(jù)訂閱者的邏輯進行推送序列元素。下面這個Excel計算就能說明一些Publisher的特點。

 

A1-A9就可以看做Publisher及其提供的元素序列。A10-A13分別是求和函數(shù)SUM(A1:A9)、平均函數(shù)AVERAGE(A1:A9)、最大值函數(shù)MAX(A1:A9)、最小值函數(shù)MIN(A1:A9),可以看作訂閱者Subscriber。假如說我們沒有A10-A13,那么A1-A9就沒有實際意義,它們并不產(chǎn)生計算。這也是響應式的一個重要特點:當沒有訂閱時發(fā)布者什么也不做。

而Flux和Mono都是Publisher在Reactor 3實現(xiàn)。Publisher提供了subscribe方法,允許消費者在有結果可用時進行消費。如果沒有消費者Publisher不會做任何事情,他根據(jù)消費情況進行響應。Publisher可能返回零或者多個,甚至可能是無限的,為了更加清晰表示期待的結果就引入了兩個實現(xiàn)模型Mono和Flux。

4. Flux

Flux是一個發(fā)出(emit)0-N個元素組成的異步序列的Publisher,可以被onComplete信號或者onError信號所終止。在響應流規(guī)范中存在三種給下游消費者調用的方法 onNext, onComplete, 和onError。下面這張圖表示了 Flux 的抽象模型:

Flux

 

以上的的講解對于初次接觸反應式編程的依然是難以理解的,所以這里有一個循序漸進的理解過程。

有些類比并不是很妥當,但是對于你循序漸進的理解這些新概念還是有幫助的。

傳統(tǒng)數(shù)據(jù)處理

我們在平常是這么寫的:

  1. public List<ClientUser> allUsers() { 
  2.     return Arrays.asList(new ClientUser("felord.cn""reactive"), 
  3.             new ClientUser("Felordcn""Reactor")); 

我們通過迭代返回值List來get這些元素進行再處理(消費),這種方式有點類似廚師做了很多菜,吃不吃在于食客。需要食客主動去來吃就行了(pull的方式),至于喜歡吃什么不喜歡吃什么自己隨意,怎么吃也自己隨意。

流式數(shù)據(jù)處理

在Java 8中我們可以改寫為流的表示:

  1. public Stream<ClientUser> allUsers() { 
  2.     return  Stream.of(new ClientUser("felord.cn""reactive"), 
  3.             new ClientUser("Felordcn""Reactor")); 

依然是廚師做了很多菜,但是這種就更加高級了一些,提供了菜品的搭配方式(不包含具體細節(jié)),食客可以按照說明根據(jù)自己的習慣搭配著去吃,一但開始概不退換,吃完為止,過期不候。

反應式數(shù)據(jù)處理

在Reactor中我們又可以改寫為Flux表示:

  1. public Flux<ClientUser> allUsers(){ 
  2.     return Flux.just(new ClientUser("felord.cn""reactive"), 
  3.             new ClientUser("Felordcn""Reactor")); 

這時候食客只需要訂餐就行了,做好了自然就呈上來,而且可以隨時根據(jù)食客的飯量進行調整。如果沒有食客訂餐那么廚師就什么都不用做。當然不止有這么點特性,不過對于方便我們理解來說這就夠了。

5. Mono

Mono 是一個發(fā)出(emit)0-1個元素的Publisher,可以被onComplete信號或者onError信號所終止。

Mono

 

這里就不翻譯了,整體和Flux差不多,只不過這里只會發(fā)出 0-1 個元素。也就是說不是有就是沒有。象Flux一樣,我們來看看Mono的演化過程以幫助理解。

傳統(tǒng)數(shù)據(jù)處理

  1. public ClientUser currentUser () { 
  2.     return isAuthenticated ? new ClientUser("felord.cn""reactive") : null

直接返回符合條件的對象或者null。

Optional 的處理方式

  1. public Optional<ClientUser> currentUser () { 
  2.     return isAuthenticated ? Optional.of(new ClientUser("felord.cn""reactive")) 
  3.             : Optional.empty(); 

這個Optional我覺得就有反應式的那種味兒了,當然它并不是反應式。當我們不從返回值Optional取其中具體的對象時,我們不清楚里面到底有沒有,但是Optional是一定客觀存在的,不會出現(xiàn)NPE問題。

反應式數(shù)據(jù)處理

  1. public Mono<ClientUser> currentUser () { 
  2.     return isAuthenticated ? Mono.just(new ClientUser("felord.cn""reactive")) 
  3.             : Mono.empty(); 

和Optional有點類似的機制,當然Mono不是為了解決NPE問題的,它是為了處理響應流中單個值(也可能是Void)而存在的。

 

6. 總結

Flux和Mono是Java反應式中的重要概念,但是很多同學包括我在開始都難以理解它們。這其實是規(guī)定了兩種流式范式,這種范式讓數(shù)據(jù)具有一些新的特性,比如基于發(fā)布訂閱的事件驅動,異步流、背壓等等。另外數(shù)據(jù)是推送(Push)給消費者的以區(qū)別于平時我們的拉(Pull)模式。同時我們可以像Stream Api一樣使用類似map、flatmap等操作符(operator)來操作它們。對Flux和Mono這兩個概念需要花一些時間去理解它們,不能操之過急。

本文轉載自微信公眾號「碼農(nóng)小胖哥」,可以通過以下二維碼關注。轉載本文請聯(lián)系碼農(nóng)小胖哥公眾號。

 

責任編輯:武曉燕 來源: 碼農(nóng)小胖哥
相關推薦

2021-07-28 20:13:04

響應式編程

2022-03-09 23:02:30

Java編程處理模型

2024-09-02 16:10:19

vue2前端

2022-08-25 11:00:19

編程系統(tǒng)

2022-01-04 20:52:50

函數(shù)異步Promise

2023-11-27 07:42:27

Reactor響應式

2025-05-06 01:14:00

系統(tǒng)編程響應式

2022-07-06 08:30:36

vuereactvdom

2013-07-11 10:37:20

Java內存模型

2017-05-24 10:12:54

前端FlexboxCSS3

2011-03-22 09:49:15

JavaScript

2019-12-26 09:15:44

網(wǎng)絡IOLinux

2012-09-21 09:21:44

函數(shù)式編程函數(shù)式語言編程

2022-07-15 08:16:56

Stream函數(shù)式編程

2021-07-14 13:12:51

2019-07-01 13:34:22

vue系統(tǒng)數(shù)據(jù)

2017-06-02 09:47:29

網(wǎng)絡分層協(xié)議

2017-03-22 11:22:04

JavaScript函數(shù)式編程

2013-06-27 09:31:37

聲明式編程命令式編程編程

2022-06-16 13:08:30

Combine響應式編程訂閱
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 丝袜美腿一区二区三区 | 久久精品免费 | 成人在线视频网 | 欧美日在线 | www.国产视频 | www.毛片 | 神马久久香蕉 | 七七婷婷婷婷精品国产 | 中文字幕在线一区二区三区 | 亚洲欧美综合精品另类天天更新 | 国产亚洲精品久久yy50 | 国产亚洲精品美女久久久久久久久久 | 精品自拍视频 | 亚洲欧美综合 | 国产精品福利网站 | 丝袜美腿一区 | 午夜影晥 | 久久久久中文字幕 | 精品国产网 | 国产一区二区在线视频 | 色婷婷激情综合 | 天天综合天天 | 久久久久久www | 可以免费观看的av | 啪啪综合网 | 一区二区三区视频 | 一色桃子av一区二区 | 91影院在线观看 | 国产三级一区二区三区 | 欧美日韩午夜精品 | 影音先锋男 | 亚洲社区在线 | 国产一卡二卡三卡 | 亚洲天堂av网 | 欧美黄色一区 | 国产精品18久久久久久白浆动漫 | 欧美视频第二页 | 免费视频一区二区 | 欧美一级在线免费观看 | 日本电影一区二区 | 成人综合一区 |