Home >Java >javaTutorial >Reactive Streams and the Flow API in Java
Reactive programming is a paradigm that deals with asynchronous data streams and the propagation of change. The Flow API, introduced in Java 9, provides a standard API for defining and working with reactive streams in Java. Understanding how to use the Flow API can help you build scalable, responsive, and resilient applications.
The Flow API is part of the java.util.concurrent package and provides interfaces for building reactive streams in Java. The key interfaces are Publisher, Subscriber, Subscription, and Processor.
Here is an example of using the Flow API to create a simple reactive stream:
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); } }
The Flow API in Java provides a powerful and flexible way to implement reactive streams, enabling developers to build scalable and responsive applications. By understanding and using the Flow API, you can handle asynchronous data streams more effectively and create more resilient Java applications.
The above is the detailed content of Reactive Streams and the Flow API in Java. For more information, please follow other related articles on the PHP Chinese website!