官术网_书友最值得收藏!

Implementing and subscribing to an Observer

When you call the subscribe() method on an Observable, an Observer is used to consume these three events by implementing its methods. Instead of specifying lambda arguments like we were doing earlier, we can implement an Observer and pass an instance of it to the subscribe() method. Do not bother yourself about onSubscribe() at the moment. Just leave its implementation empty until we discuss it at the end of this chapter:

    import io.reactivex.Observable;
import io.reactivex.Observer;
import io.reactivex.disposables.Disposable;

public class Launcher {

public static void main(String[] args) {

Observable<String> source =
Observable.just("Alpha", "Beta", "Gamma", "Delta",
"Epsilon");

Observer<Integer> myObserver = new Observer<Integer>() {
@Override
public void onSubscribe(Disposable d) {
//do nothing with Disposable, disregard for now

}

@Override
public void onNext(Integer value) {
System.out.println("RECEIVED: " + value);
}

@Override
public void onError(Throwable e) {
e.printStackTrace();
}

@Override
public void onComplete() {
System.out.println("Done!");
}
};

source.map(String::length).filter(i -> i >= 5)
.subscribe(myObserver);
}
}

The output is as follows:

    RECEIVED: 5
RECEIVED: 5
RECEIVED: 5
RECEIVED: 7
Done!

We quickly create an Observer<Integer> that serves as our Observer, and it will receive integer length emissions. Our Observer receives emissions at the end of an Observable chain and serves as the endpoint where the emissions are consumed. By consumed, this means they reach the end of the process where they are written to a database, text file, a server response, displayed in a UI, or (in this case) just printed to the console.

To further explain this example in detail, we start with string emissions at our source. We declare our Observer in advance and pass it to the subscribe() method at the end of our Observable chain. Note that each string is transformed to its length. The onNext() method receives each integer length emission and prints it using System.out.println("RECEIVED: " + value). We will not get any errors running this simple process, but if one did occur anywhere in our Observable chain, it will be pushed to our  onError() implementation on Observer, where the stack trace of Throwable will be printed. Finally, when the source has no more emissions (after pushing "Epsilon"), it will call onComplete() up the chain all the way to the Observer, where its onComplete() method will be called and print Done! to the console.

主站蜘蛛池模板: 同心县| 八宿县| 临沂市| 沙田区| 蛟河市| 闽清县| 郧西县| 华容县| 临沧市| 岳普湖县| 诏安县| 京山县| 公安县| 孝昌县| 泸溪县| 双柏县| 富源县| 山东省| 正定县| 烟台市| 卢龙县| 福海县| 定边县| 云和县| 甘肃省| 梁河县| 大姚县| 仪陇县| 台前县| 西乌| 泸定县| 托克托县| 黑水县| 永年县| 潞城市| 乌恰县| 延边| 吉安县| 淮南市| 株洲市| 西安市|