Observables
- RxJava - How Observable works
- RxJava - Creating Observables
- RxJava - Using Flowable
- RxJava - Using Observable
- RxJava - Single Observable
- RxJava - Maybe Observable
- RxJava - Completable Observable
- RxJava - Using CompositeDisposable
Operators
- RxJava - Creating Operators
- RxJava - Transforming Operators
- RxJava - Filtering Operators
- RxJava - Combining Operators
- RxJava - Utility Operators
- RxJava - Conditional Operators
- RxJava - Mathematical Operators
- RxJava - Connectable Operators
Subjects
- RxJava - Subjects
- RxJava - PublishSubject
- RxJava - BehaviorSubject
- RxJava - ReplaySubject
- RxJava - AsyncSubject
- RxJava - UnicastSubject
Schedulers
- RxJava - Schedulers
- RxJava - Trampoline Scheduler
- RxJava - NewThread Scheduler
- RxJava - Computation Scheduler
- RxJava - IO Scheduler
- RxJava - From Scheduler
Miscellaneous
RxJava Useful Resources
RxJava - Transforming Operators
Following are the operators which are used to transform an item emitted from an Observable.
| Sr.No. | Operator & Description |
|---|---|
| 1 |
buffer Gathers items from Observable into bundles periodically and then emit the bundles rather than items. |
| 2 |
flatMap Used in nested observables. Transforms items into Observables. Then flatten the items into single Observable. |
| 3 |
groupBy Divide an Observable into set of Observables organized by key to emit different group of items. |
| 4 |
map Apply a function to each emitted item to transform it. |
| 5 |
scan Apply a function to each emitted item, sequentially and then emit the successive value. |
| 6 |
window Gathers items from Observable into Observable windows periodically and then emit the windows rather than items. |
Example - Transforming Letters to Upper case using map Operator
ObservableTester.java
package com.tutorialspoint;
import io.reactivex.rxjava3.core.Observable;
//Using map operator to tranform an item emitted
public class ObservableTester {
public static void main(String[] args) {
String[] letters = {"a", "b", "c", "d", "e", "f", "g"};
final StringBuilder result = new StringBuilder();
Observable<String> observable = Observable.fromArray(letters);
observable
.map(String::toUpperCase)
.subscribe( letter -> result.append(letter));
System.out.println(result);
}
}
Output
Compile and Run the code to verify the following output −
ABCDEFG
Example - Flatten internal observables using flatmap Operator
ObservableTester.java
package com.tutorialspoint;
import java.util.concurrent.TimeUnit;
import io.reactivex.rxjava3.core.Observable;
import io.reactivex.rxjava3.schedulers.Schedulers;
//Using flatmap operator to flatten observables
public class ObservableTester {
public static void main(String[] args) throws InterruptedException {
Observable<String> userIds = Observable.just("user1", "user2", "user3");
userIds.flatMap(userId -> getUserDetails(userId))
.subscribe(userDetails -> System.out.println("Received: " + userDetails));
// Keep the main thread alive to see the asynchronous results
Thread.sleep(1000);
}
// Simulate an asynchronous network call to get user details
public static Observable<String> getUserDetails(String userId) {
return Observable.just("User Details of " + userId)
.delay(100, TimeUnit.MILLISECONDS)
.subscribeOn(Schedulers.io());
}
}
Output
Compile and Run the code to verify the following output −
Received: User Details of user3 Received: User Details of user1 Received: User Details of user2