各位看官们大家好,上一回中咱们说的例子是"解决ViewPager2中的滑动冲突",本章回中介绍的例子是" RxJava基本用法"。闲话休提,言归正转,让我们一起Talk Android吧!
概念介绍
在程序中经常需要使用事件流,特别是一些网络操作,RxJava
是一种常用的事件流框架,而且还提供异步功能。本章回中我们将介绍RxJava
的基本用法,我们计划在后续章回中详细介绍该框架。
RxJava使用了观察者模式,如果大家不了解此模式,建议先自行了解,不然无法理解该框架的操作。
使用方法
- 创建被观察者,同时创建事件流,然后分发事件;
- 创建观察者,重写回调方法,在回调方法中可以收到被观察者分发的事件;
- 通过
subscribe
操作把被观察者和观察者连接在一起,观察者便可以监听被观察者分发的事件;
示例代码
private void rxAndroidEx() {
// 创建被观察者,同时创建事件流,然后分发事件;
Observable<String> observable = Observable.create(new ObservableOnSubscribe<String>() {
@Override
public void subscribe(@io.reactivex.rxjava3.annotations.NonNull ObservableEmitter<String> emitter) throws Throwable {
emitter.onNext("Event 1");
emitter.onNext("Event 2");
emitter.onNext("Event 3");
emitter.onComplete();
}
});
// 创建观察者,重写回调方法,在回调方法中可以收到被观察者分发的事件;
Observer<String> observer = new Observer<String>() {
@Override
public void onSubscribe(@io.reactivex.rxjava3.annotations.NonNull Disposable d) {
Log.d(TAG, "onSubscribe: ");
}
@Override
public void onNext(@io.reactivex.rxjava3.annotations.NonNull String s) {
Log.d(TAG, "onNext: "+s);
}
@Override
public void onError(@io.reactivex.rxjava3.annotations.NonNull Throwable e) {
Log.d(TAG, "onError: "+e.toString());
}
@Override
public void onComplete() {
Log.d(TAG, "onComplete: ");
}
};
//通过subscribe操作把被观察者和观察者连接在一起
observable.subscribe(observer);
}
在上面的代码中,被观察者发了三个事件的,观察者会依据收到三个事件,然后结束事件流。编译运行上面的程序可以得到以下运行结果:
onSubscribe:
onNext: Event1
onNext: Event2
onNext: Event3
onComplete
此外,在使用RxJava时需要提前在gradle中添加它的依赖,如果是在Android中使用,也可能添加RxAndroid依赖。Rxjava还有很多使用方法,我们暂且不表,本章回中只介绍它的基本用法,当作是个引子,后续章回中将介绍它的其它使用方法。
看官们,关于"RxJava基本用法"的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!