RxJava - From Scheduler



Schedulers.from(Executor) method converts an Executor into a new Scheduler instance.

Example - Usage of Schedulers.from()

ObservableTester.java

package com.tutorialspoint; import java.util.Random; import java.util.concurrent.Executors; import io.reactivex.rxjava3.core.Observable; import io.reactivex.rxjava3.schedulers.Schedulers; public class ObservableTester { public static void main(String[] args) throws InterruptedException { Observable.just("A", "AB", "ABC") .flatMap(v -> getLengthWithDelay(v) .doOnNext(s -> System.out.println("Processing Thread " + Thread.currentThread().getName())) .subscribeOn(Schedulers.from(Executors.newFixedThreadPool(3)))) .subscribe(length -> System.out.println("Receiver Thread " + Thread.currentThread().getName() + ", Item length " + length)); Thread.sleep(10000); } protected static Observable<Integer> getLengthWithDelay(String v) { Random random = new Random(); try { Thread.sleep(random.nextInt(3) * 1000); return Observable.just(v.length()); } catch (InterruptedException e) { e.printStackTrace(); } return null; } }

Output

Compile and Run the code to verify the following output −

Processing Thread pool-1-thread-1
Receiver Thread pool-1-thread-1, Item length 1
Processing Thread pool-3-thread-1
Receiver Thread pool-3-thread-1, Item length 2
Processing Thread pool-4-thread-1
Receiver Thread pool-4-thread-1, Item length 3
Advertisements