欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Java中的reactive stream協(xié)議

 更新時間:2021年06月02日 09:56:44   作者:flydean  
Stream大家應(yīng)該都很熟悉了,java8中為所有的集合類都引入了Stream的概念。優(yōu)雅的鏈?zhǔn)讲僮鳎魇教幚磉壿?,相信用過的人都會愛不釋手。本文將詳細介紹Java中的reactive stream協(xié)議。

背景

每個數(shù)據(jù)流都有一個生產(chǎn)者一個消費者。生產(chǎn)者負(fù)責(zé)產(chǎn)生數(shù)據(jù),而消費者負(fù)責(zé)消費數(shù)據(jù)。如果是同步系統(tǒng),生產(chǎn)一個消費一個沒什么問題。但是如果在異步系統(tǒng)中,就會產(chǎn)生問題。

因為生產(chǎn)者無法感知消費者的狀態(tài),不知道消費者到底是繁忙狀態(tài)還是空閑狀態(tài),是否有能力去消費更多的數(shù)據(jù)。

一般來說數(shù)據(jù)隊列的長度都是有限的,即使沒有做限制,但是系統(tǒng)的內(nèi)存也是有限的。當(dāng)太多的數(shù)據(jù)沒有被消費的話,會導(dǎo)致內(nèi)存溢出或者數(shù)據(jù)得不到即使處理的問題。

這時候就需要back-pressure了。

如果消息接收方消息處理不過來,則可以通知消息發(fā)送方,告知其正在承受壓力,需要降低負(fù)載。back-pressure是一種消息反饋機制,從而使系統(tǒng)得以優(yōu)雅地響應(yīng)負(fù)載, 而不是在負(fù)載下崩潰。

而reactive stream的目的就是用來管理異步服務(wù)的流數(shù)據(jù)交換,并能夠讓接收方自主決定接受數(shù)據(jù)的頻率。back-pressure就是reactive stream中不可或缺的一部分。

什么是reactive stream

上面我們講到了reactive stream的作用,大家應(yīng)該對reactive stream有了一個基本的了解。這里我們再給reactive stream做一個定義:

reactive stream就是一個異步stream處理的標(biāo)準(zhǔn),它的特點就是非阻塞的back pressure。

reactive stream只是一個標(biāo)準(zhǔn),它定義了實現(xiàn)非阻塞的back pressure的最小區(qū)間的接口,方法和協(xié)議。

所以reactive stream其實有很多種實現(xiàn)的,不僅僅是java可以使用reactive stream,其他的編程語言也可以。

reactive stream只是定義了最基本的功能,各大實現(xiàn)在實現(xiàn)了基本功能的同時可以自由擴展。

目前reactive stream最新的java版本是1.0.3,是在2019年8月23發(fā)布的。它包含了java API,協(xié)議定義文件,測試工具集合和具體的實現(xiàn)例子。

深入了解java版本的reactive stream

在介紹java版本的reactive stream之前,我們先回顧一下reactive stream需要做哪些事情:

1.能夠處理無效數(shù)量的消息

2.消息處理是有順序的

3.可以異步的在組件之間傳遞消息

4.一定是非阻塞和backpressure的

為了實現(xiàn)這4個功能,reactive stream定義了4個接口,Publisher,Subscriber,Subscription,Processor。這四個接口實際上是一個觀察者模式的實現(xiàn)。接下來我們詳細來分析一下各個接口的作用和約定。

Publisher

先看下Publisher的定義:

public interface Publisher<T> {
    public void subscribe(Subscriber<? super T> s);
}

Publisher就是用來生成消息的。它定義了一個subscribe方法,傳入一個Subscriber。這個方法用來將Publisher和Subscriber進行連接。

一個Publisher可以連接多個Subscriber。

每次調(diào)用subscribe建立連接,都會創(chuàng)建一個新的Subscription,Subscription和subscriber是一一對應(yīng)的。

一個Subscriber只能夠subscribe一次Publisher。

如果subscribe失敗或者被拒絕,則會出發(fā)Subscriber.onError(Throwable)方法。

Subscriber

先看下Subscriber的定義:

public interface Subscriber<T> {
    public void onSubscribe(Subscription s);
    public void onNext(T t);
    public void onError(Throwable t);
    public void onComplete();
}

Subscriber就是消息的接收者。

在Publisher和Subscriber建立連接的時候會觸發(fā)onSubscribe(Subscription s)方法。

當(dāng)調(diào)用Subscription.request(long)方法時,onNext(T t)會被觸發(fā),根據(jù)request請求參數(shù)的大小,onNext會被觸發(fā)一次或者多次。

在發(fā)生異常或者結(jié)束時會觸發(fā)onError(Throwable t)或者onComplete()方法。

Subscription

先看下Subscription的定義:

public interface Subscription {
    public void request(long n);
    public void cancel();
}

Subscription代表著一對一的Subscriber和Publisher之間的Subscribe關(guān)系。

request(long n)意思是向publisher請求多少個events,這會觸發(fā)Subscriber.onNext方法。

cancel()則是請求Publisher停止發(fā)送信息,并清除資源。

Processor

先看下Processor的定義:

public interface Processor<T, R> extends Subscriber<T>, Publisher<R> {
}

Processor即是Subscriber又是Publisher,它代表著一種處理狀態(tài)。

JDK中reactive stream的實現(xiàn)

在JDK中java.util.concurrent.Flow就是reactive stream語義的一種實現(xiàn)。

Flow從JDK9就開始有了。我們看下它的結(jié)構(gòu):

從上圖我們可以看到在JDK中Flow是一個final class,而Subscriber,Publisher,Subscription,Processor都是它的內(nèi)部類。

總結(jié)

reactive stream的出現(xiàn)有效的解決了異步系統(tǒng)中的背壓問題。只不過reactive stream只是一個接口標(biāo)準(zhǔn)或者說是一種協(xié)議,具體的實現(xiàn)還需要自己去實現(xiàn)。

以上就是詳解Java中的reactive stream協(xié)議的詳細內(nèi)容,更多關(guān)于Java中的reactive stream協(xié)議的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java實現(xiàn)Dijkstra算法

    java實現(xiàn)Dijkstra算法

    這篇文章主要為大家詳細介紹了java實現(xiàn)Dijkstra算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • java實現(xiàn)登錄窗口

    java實現(xiàn)登錄窗口

    這篇文章主要為大家詳細介紹了java實現(xiàn)登錄窗口,含驗證碼驗證、賬戶注冊等,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • springboot集成es詳解

    springboot集成es詳解

    這篇文章主要介紹了springboot集成es,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Eclipse下Javassist正確使用方法代碼解析

    Eclipse下Javassist正確使用方法代碼解析

    這篇文章主要介紹了Eclipse下Javassist正確使用方法代碼解析,javassist-3.15.0-ga.jar包是一款在java開發(fā)中十分重要的jar文件包,需要的朋友可以參考下,文中附下載鏈接。
    2017-12-12
  • Java 在PDF中繪制形狀的兩種方法

    Java 在PDF中繪制形狀的兩種方法

    這篇文章主要介紹了Java 在 PDF 中繪制形狀的兩種實現(xiàn)方法,文中講解非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • java微信公眾號支付開發(fā)之現(xiàn)金紅包

    java微信公眾號支付開發(fā)之現(xiàn)金紅包

    這篇文章主要為大家詳細介紹了java微信公眾號支付開發(fā)之現(xiàn)金紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Spring 事務(wù)事件監(jiān)控及實現(xiàn)原理解析

    Spring 事務(wù)事件監(jiān)控及實現(xiàn)原理解析

    本文首先會使用實例進行講解Spring事務(wù)事件是如何使用的,然后會講解這種使用方式的實現(xiàn)原理。感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • Mybatis generator修改Mapper.java文件實現(xiàn)詳解

    Mybatis generator修改Mapper.java文件實現(xiàn)詳解

    這篇文章主要為大家介紹了Mybatis generator修改Mapper.java文件實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Spring的@ConfigurationProperties注解詳解

    Spring的@ConfigurationProperties注解詳解

    這篇文章主要介紹了Spring的@ConfigurationProperties注解詳解,@ConfigurationProperties該注解是用來獲取yml或者properties配置文件的配置信息,下面根據(jù)一些配置信息給出案例代碼進行講解,需要的朋友可以參考下
    2023-11-11
  • 解析MapStruct轉(zhuǎn)換javaBean時出現(xiàn)的詭異事件

    解析MapStruct轉(zhuǎn)換javaBean時出現(xiàn)的詭異事件

    在項目中用到了MapStruct,對其可以轉(zhuǎn)換JavaBean特別好奇,今天小編給大家分享一個demo給大家講解MapStruct轉(zhuǎn)換javaBean時出現(xiàn)的詭異事件,感興趣的朋友一起看看吧
    2021-09-09

最新評論