ホームページ >Java >&#&チュートリアル >Java のリアクティブ ストリームと Flow API
リアクティブ プログラミングは、非同期データ ストリームと変更の伝播を扱うパラダイムです。 Java 9 で導入された Flow API は、Java でリアクティブ ストリームを定義して操作するための標準 API を提供します。 Flow API の使用方法を理解すると、スケーラブルで応答性が高く、回復力のあるアプリケーションを構築するのに役立ちます。
Flow API は java.util.concurrent パッケージの一部であり、Java でリアクティブ ストリームを構築するためのインターフェイスを提供します。主要なインターフェースは、パブリッシャー、サブスクライバー、サブスクリプション、プロセッサーです。
ここでは、Flow API を使用して単純なリアクティブ ストリームを作成する例を示します。
import java.util.concurrent.Flow.*; public class SimplePublisher implements Publisher<String> { private String[] data; public SimplePublisher(String[] data) { this.data = data; } @Override public void subscribe(Subscriber<? super String> subscriber) { subscriber.onSubscribe(new Subscription() { private int index = 0; private boolean canceled = false; @Override public void request(long n) { for (int i = 0; i < n && index < data.length && !canceled; i++) { subscriber.onNext(data[index++]); } if (index == data.length) { subscriber.onComplete(); } } @Override public void cancel() { canceled = true; } }); } }
import java.util.concurrent.Flow.*; public class SimpleSubscriber implements Subscriber<String> { private Subscription subscription; @Override public void onSubscribe(Subscription subscription) { this.subscription = subscription; subscription.request(1); // Request the first item } @Override public void onNext(String item) { System.out.println("Received: " + item); subscription.request(1); // Request the next item } @Override public void onError(Throwable throwable) { throwable.printStackTrace(); } @Override public void onComplete() { System.out.println("All items received."); } }
public class FlowApiExample { public static void main(String[] args) { String[] data = {"Hello", "world", "from", "Flow", "API"}; SimplePublisher publisher = new SimplePublisher(data); SimpleSubscriber subscriber = new SimpleSubscriber(); publisher.subscribe(subscriber); } }
Java の Flow API は、リアクティブ ストリームを実装する強力かつ柔軟な方法を提供し、開発者がスケーラブルで応答性の高いアプリケーションを構築できるようにします。 Flow API を理解して使用することで、非同期データ ストリームをより効果的に処理し、より回復力のある Java アプリケーションを作成できます。
以上がJava のリアクティブ ストリームと Flow APIの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。