搜尋
首頁Javajava教程java9新功能Reactive Stream響應式程式設計API怎麼用

一、Java9 Reactive Stream API

Java 9提供了一組定義響應式串流程式設計的介面。所有這些介面都作為靜態內部介面定義在java.util.concurrent.Flow類別裡面。

java9新功能Reactive Stream響應式程式設計API怎麼用

以下是Java 響應式程式設計中的一些重要角色和概念,先簡單理解一下

發布者(Publisher)是潛在的無限數量的有序資料元素的生產者。它根據收到的需求(subscription)向目前訂閱者發布一定數量的資料元素。

訂閱者(Subscriber)從發布者訂閱並接收資料元素。與發布者建立訂閱關係後,發布者向訂閱者發送訂閱令牌(subscription),訂閱者可以根據自己的處理能力請求發布者發布資料元素的數量。

訂閱令牌(subscription)表示訂閱者與發布者之間建立的訂閱關係。當建立訂閱關係後,發布者將其傳遞給訂閱者。訂閱者使用訂閱令牌與發布者進行交互,例如請求資料元素的數量或取消訂閱。

二、Java響應式程式設計四大介面

2.1.Subscriber Interface(訂閱者訂閱介面)

public static interface Subscriber<T> {
    public void onSubscribe(Subscription subscription);
    public void onNext(T item);
    public void onError(Throwable throwable);
    public void onComplete();
}

onSubscribe#:在發布者接受訂閱者的訂閱動作之後,發布任何的訂閱訊息之前被呼叫。新建立的Subscription訂閱令牌物件透過此方法傳遞給訂閱者。

onNext:下一個待處理的資料項目的處理函數

#onError:在發布者或訂閱遇到不可復原的錯誤時呼叫

onComplete:當沒有訂閱者呼叫(包括onNext()方法)發生時呼叫。

2.2.Subscription Interface (訂閱令牌介面)

訂閱令牌物件透過Subscriber.onSubscribe()方法傳遞

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

# request(long n)是無阻塞背壓概念背後的關鍵方法。訂閱者使用它來請求n個以上的消費項目。這樣,訂閱者就控制了它目前能夠接收多少個資料。 cancel()由訂閱者主動來取消其訂閱,取消後將不會在接收任何資料訊息。

2.3.Publisher Interface(發布者介面)

@FunctionalInterface
public static interface Publisher<T> {
    public void subscribe(Subscriber<? super T> subscriber);
}

呼叫此方法,建立訂閱者Subscriber與發布者Publisher之間的訊息訂閱關係。

2.4.Processor Interface(處理器介面)

處理者Processor 可以同時充當訂閱者和發布者,起到轉換發布者——訂閱者管道中的元素的作用。用於將發布者T類型的資料元素,接收並轉換為類型R的資料並發布。

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

二、實戰案例

現在我們要去實作上面的四個介面來完成響應式程式設計

Subscription Interface訂閱令牌接口通常不需要我們自己編程去實現,我們只需要在知道request()方法和cancle()方法意義即可。

Publisher Interface發布者接口,Java 9 已經預設為我們提供了實作SubmissionPublisher,該實作類別除了實作Publisher介面的方法外,提供了一個方法叫做submit()來完成訊息資料的發送。

Subscriber Interface訂閱者接口,通常需要我們自己去實作。因為在資料訂閱接收之後,不同的業務有不同的處理邏輯。

Processor實際上是Publisher Interface和Subscriber Interface的集合體,有需要資料類型轉換及資料處理的需求才去實現這個介面

下面的例子實現的式字串的資料訊息訂閱處理

實作訂閱者Subscriber Interface

import java.util.concurrent.Flow;
public class MySubscriber implements Flow.Subscriber<String> {
  private Flow.Subscription subscription;  //订阅令牌
  @Override
  public void onSubscribe(Flow.Subscription subscription) {
      System.out.println("订阅关系建立onSubscribe: " + subscription);
      this.subscription = subscription;
      subscription.request(2);
  }
  @Override
  public void onNext(String item) {
      System.out.println("item: " + item);
      // 一个消息处理完成之后,可以继续调用subscription.request(n);向发布者要求数据发送
      //subscription.request(n);
  }
  @Override
  public void onError(Throwable throwable) {
      System.out.println("onError: " + throwable);
  }
  @Override
  public void onComplete() {
      System.out.println("onComplete");
  }
}

SubmissionPublisher訊息發布者

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Flow;
import java.util.concurrent.SubmissionPublisher;
public class SubmissionPublisherExample {
  public static void main(String[] args) throws InterruptedException {
      ExecutorService executor = Executors.newFixedThreadPool(1);
      SubmissionPublisher<String> sb = new SubmissionPublisher<>(executor, Flow.defaultBufferSize());
      sb.subscribe(new MySubscriber());   //建立订阅关系,可以有多个订阅者
      sb.submit("数据 1");  //发送消息1
      sb.submit("数据 2"); //发送消息2
      sb.submit("数据 3"); //发送消息3
      executor.shutdown();
  }
}

控制台列印輸出結果

訂閱關係建立
onSubscribe: java.util.concurrent.SubmissionPublisher$BufferedSubscription@27e81a39
item: 資料1
item: 資料2

#請注意:即使發布者submit了3條數據,MySubscriber也僅收到了2條數據進行了處理。是因為我們在MySubscriber#onSubscribe()方法中使用了subscription.request(2);。這就是「背壓」的響應式程式設計效果,我有能力處理多少數據,就會通知訊息發布者給多少數據。

以上是java9新功能Reactive Stream響應式程式設計API怎麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
JVM如何處理操作系統API的差異?JVM如何處理操作系統API的差異?Apr 27, 2025 am 12:18 AM

JVM通過JavaNativeInterface(JNI)和Java標準庫處理操作系統API差異:1.JNI允許Java代碼調用本地代碼,直接與操作系統API交互。 2.Java標準庫提供統一API,內部映射到不同操作系統API,確保代碼跨平台運行。

Java 9影響平台獨立性中引入的模塊化如何?Java 9影響平台獨立性中引入的模塊化如何?Apr 27, 2025 am 12:15 AM

modularitydoesnotdirectlyaffectJava'splatformindependence.Java'splatformindependenceismaintainedbytheJVM,butmodularityinfluencesapplicationstructureandmanagement,indirectlyimpactingplatformindependence.1)Deploymentanddistributionbecomemoreefficientwi

什麼是字節碼,它與Java的平台獨立性有何關係?什麼是字節碼,它與Java的平台獨立性有何關係?Apr 27, 2025 am 12:06 AM

BytecodeinJavaistheintermediaterepresentationthatenablesplatformindependence.1)Javacodeiscompiledintobytecodestoredin.classfiles.2)TheJVMinterpretsorcompilesthisbytecodeintomachinecodeatruntime,allowingthesamebytecodetorunonanydevicewithaJVM,thusfulf

為什麼Java被認為是一種獨立於平台的語言?為什麼Java被認為是一種獨立於平台的語言?Apr 27, 2025 am 12:03 AM

javaachievesplatformIndependencEthroughThoJavavIrtualMachine(JVM),wodecutesbytecodeonyanydenanydevicewithajvm.1)javacodeiscompiledintobytecode.2)

圖形用戶界面(GUIS)如何提出Java平台獨立性的挑戰?圖形用戶界面(GUIS)如何提出Java平台獨立性的挑戰?Apr 27, 2025 am 12:02 AM

JavaGUI開發中的平台獨立性面臨挑戰,但可以通過使用Swing、JavaFX,統一外觀,性能優化,第三方庫和跨平台測試來應對。 JavaGUI開發依賴於AWT和Swing,Swing旨在提供跨平台一致性,但實際效果因操作系統不同而異。解決方案包括:1)使用Swing和JavaFX作為GUI工具包;2)通過UIManager.setLookAndFeel()統一外觀;3)優化性能以適應不同平台;4)使用如ApachePivot或SWT的第三方庫;5)進行跨平台測試以確保一致性。

Java開發的哪些方面取決於平台?Java開發的哪些方面取決於平台?Apr 26, 2025 am 12:19 AM

JavadevelovermentIrelyPlatForm-DeTueTososeVeralFactors.1)JVMVariationsAffectPerformanceNandBehaviorAcroSsdifferentos.2)Nativelibrariesviajnijniiniininiinniinindrododerplatefform.3)

在不同平台上運行Java代碼時是否存在性能差異?為什麼?在不同平台上運行Java代碼時是否存在性能差異?為什麼?Apr 26, 2025 am 12:15 AM

Java代碼在不同平台上運行時會有性能差異。 1)JVM的實現和優化策略不同,如OracleJDK和OpenJDK。 2)操作系統的特性,如內存管理和線程調度,也會影響性能。 3)可以通過選擇合適的JVM、調整JVM參數和代碼優化來提升性能。

Java平台獨立性有什麼局限性?Java平台獨立性有什麼局限性?Apr 26, 2025 am 12:10 AM

Java'splatFormentenceHaslimitations不包括PerformanceOverhead,versionCompatibilityIsissues,挑戰WithnativelibraryIntegration,Platform-SpecificFeatures,andjvminstallation/jvminstallation/jvmintenance/jeartenance.therefactorscomplicatorscomplicatethe“ writeOnce”

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。