- 
                Notifications
    
You must be signed in to change notification settings  - Fork 7.6k
 
Blocking Observable Operators
        akarnokd edited this page Jun 26, 2020 
        ·
        50 revisions
      
    This section explains the BlockingObservable subclass. A Blocking Observable extends the ordinary Observable class by providing a set of operators on the items emitted by the Observable that block.
To transform an Observable into a BlockingObservable, use the Observable.toBlocking( ) method or the BlockingObservable.from( ) method.
- 
forEach( )— invoke a function on each item emitted by the Observable; block until the Observable completes - 
first( )— block until the Observable emits an item, then return the first item emitted by the Observable - 
firstOrDefault( )— block until the Observable emits an item or completes, then return the first item emitted by the Observable or a default item if the Observable did not emit an item - 
last( )— block until the Observable completes, then return the last item emitted by the Observable - 
lastOrDefault( )— block until the Observable completes, then return the last item emitted by the Observable or a default item if there is no last item - 
mostRecent( )— returns an iterable that always returns the item most recently emitted by the Observable - 
next( )— returns an iterable that blocks until the Observable emits another item, then returns that item - 
latest( )— returns an iterable that blocks until or unless the Observable emits an item that has not been returned by the iterable, then returns that item - 
single( )— if the Observable completes after emitting a single item, return that item, otherwise throw an exception - 
singleOrDefault( )— if the Observable completes after emitting a single item, return that item, otherwise return a default item - 
toFuture( )— convert the Observable into a Future - 
toIterable( )— convert the sequence emitted by the Observable into an Iterable - 
getIterator( )— convert the sequence emitted by the Observable into an Iterator 
This documentation accompanies its explanations with a modified form of "marble diagrams." Here is how these marble diagrams represent Blocking Observables:
- javadoc: 
BlockingObservable - javadoc: 
toBlocking() - javadoc: 
BlockingObservable.from() 
| operator | result when it acts on | equivalent in Rx.NET | ||
|---|---|---|---|---|
| Observable that emits multiple items | Observable that emits one item | Observable that emits no items | ||
Observable.first | 
the first item | the single item | NoSuchElement | firstAsync | 
BlockingObservable.first | 
the first item | the single item | NoSuchElement | first | 
Observable.firstOrDefault | 
the first item | the single item | the default item | firstOrDefaultAsync | 
BlockingObservable.firstOrDefault | 
the first item | the single item | the default item | firstOrDefault | 
Observable.last | 
the last item | the single item | NoSuchElement | lastAsync | 
BlockingObservable.last | 
the last item | the single item | NoSuchElement | last | 
Observable.lastOrDefault | 
the last item | the single item | the default item | lastOrDefaultAsync | 
BlockingObservable.lastOrDefault | 
the last item | the single item | the default item | lastOrDefault | 
Observable.single | 
Illegal Argument | the single item | NoSuchElement | singleAsync | 
BlockingObservable.single | 
Illegal Argument | the single item | NoSuchElement | single | 
Observable.singleOrDefault | 
Illegal Argument | the single item | the default item | singleOrDefaultAsync | 
BlockingObservable.singleOrDefault | 
Illegal Argument | the single item | the default item | singleOrDefault | 
Copyright (c) 2016-present, RxJava Contributors.
Twitter @RxJava | Gitter @RxJava