=====================================================================
Observable o1 = Observable.create(new ObservableOnSubscribe() {
@Override
public void subscribe(ObservableEmitter e) {
try {
Thread.sleep(1000); // 假设此处是耗时操作
} catch (Exception ee) {
ee.printStackTrace();
}
e.onNext(“1”);
e.onComplete();
}
});
Observable o2 = Observable.create(new ObservableOnSubscribe() {
@Override
public void subscribe(ObservableEmitter e) {
try {
Thread.sleep(1000); // 假设此处是耗时操作
} catch (Exception ee) {
ee.printStackTrace();
}
e.onNext(“2”);
e.onComplete();
}
});
o1.flatMap(new Function<String, ObservableSource>() {
@Override
public ObservableSource apply(String s) throws Exception {
return o2;
}
})
.observeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer() {
@Override
public void onSubscribe(Disposable d) {
}
@Override
public void onNext(String s) {
}
@Override
public void onError(Throwable e) {
}
@Override
public void onComplete() {
}
});
FlatMap是变换操作符,先处理第一个请求o1,再发送下一个o2。
====================================================================
Observable.concat(o1, o2)
.compose(RxUtil.applySchedulers())
.compose(lifecycleProvider.bindUntilEvent(Lifecycle.Event.ON_DESTROY))
.subscribe(new Observer() {
@Override
public void onSubscribe(Disposable d) {
}
@Override
public void onNext(String s) {
Log.d(TAG, s);
if (“1”.equals(s)) {
ToastUtil.showToast(“concat: 1”);
} else if (“2”.equals(s)) {
ToastUtil.showToast(“concat: 2”);
}
}
@Override
public void onError(Throwable e) {
}
@Override
public void onComplete() {
}
});
Concat是一个聚合操作符,我们看到有两个Observable:o1和o2,将它们通过concat聚合在一起,系统会先处理o1,然后再处理o2,所以我们在subscribe接收的时候并不知道具体类型,所以用Object代替,在实际过程中进行类型判断。
===================================================================
o1 = o1.subscribeOn(Schedulers.io());
o2 = o2.subscribeOn(Schedulers.io());
Observable.merge(o1, o2).compose(RxUtil.applySchedulers()).subscribe(new Consumer() {
@Override
public void accept(Integer integer) throws Exception {
Log.d(TAG, integer + “”);
}
});
注意:一定要在o1和o2后面加上.subscribeOn(Schedulers.io()),否则就是串行了。
Merge是将两个Observable:o1和o2同时发送,然后再根据达到的结果进行处理,同理这边也用Object表示。
最后
我这里整理了一份完整的学习思维以及Android开发知识大全PDF。
当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
理这边也用Object表示。
最后
我这里整理了一份完整的学习思维以及Android开发知识大全PDF。
[外链图片转存中…(img-SEB7MxNx-1715873595526)]
当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!