rxjava操作符结合使用场景简介
前言
本文将通过实际的例子来介绍rx相关的操作符,如果对rxjava还不熟悉的同学请先查看rxjava相关基础姿势再来查看本文
准备
本文依赖rxjava版本如下
implementation 'io.reactivex.rxjava2:rxjava:2.1.15'
implementation 'io.reactivex.rxjava2:rxandroid:2.0.2'
目录
目前根据实际使用场景一共总结了7个例子,后面如果还有的话我会持续更新
- 网络请求嵌套(A请求成功后再进行B请求的情况)
- 网络请求合并(A请求和B请求成功后合并数据在更新ui)
- 三级缓存,从内存/磁盘/网络中读取数据
- 组合判断(当A输入框和B输入框输入内容满足条件的时候Button才变成可点击的)
- 网络请求出错重试
- 联想搜索优化(用户x秒后没有再输入新的内容,进行搜索请求)
- 防止多次点击
1. 网络请求嵌套
先执行请求1成功后执行请求2.
这里通过
flatMap
操作符实现,将一个Observable
转换成另一个Observable
网络请求的话这里自己模拟的代码如下
object ExampleRepo {
fun getRequest1() = Observable.just(1)
fun getRequest2(i: Int) = Observable.just(2)
}
执行请求代码如下
ExampleRepo.getRequest1()
.flatMap {
ExampleRepo.getRequest2(it)
}
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(
{
Log.i("zhuliyuan", "onNext: $it")
},
{
Log.i("zhuliyuan", "onError: $it")
},
{
Log.i("zhuliyuan", "onComplete")
},
{
Log.i("zhuliyuan", "onSubscribe")
}
)
结果与预期并无差异
2. 网络请求合并
将请求1和请求2成功后的数据合并供ui显示.
这里会用到
zip
操作符,合并多个被观察者Observable
发送的事件,并最终发送
模拟网络请求代码如下
object ExampleRepo {
fun getRequest1() = Observable.just(1)
fun getRequest2() = Observable.just(2)
}
执行请求我们将request1的结果1和request2的结果2相加,最后结果应该为3
Observable.zip(
ExampleRepo.getRequest1(),
ExampleRepo.getRequest2(),
BiFunction<Int, Int, Int> {
t1, t2 ->
t1 + t2
})
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(
{
Log.i("zhuliyuan", "onNext: $it")
},
{
Log.i("zhuliyuan", "onError: $it")
},
{
Log.i("zhuliyuan", "onComplete")
},
{
Log.i("zhuliyuan", "onSubscribe")
}
)
结果和预期相同
3. 三级缓存
先从内存中获取数据,没获取到的话再从磁盘获取数据,还是没取到的话最后通过网络获取数据.
这里会用到
concat
操作符组合多个被观察者一起发送数据,合并后 按发送顺序串行执行
var memory: String? = null
var disk: String? = "磁盘获取数据"
var net: String? = "网络获取数据"
fun getData() {
val memoryObservable = Observable.create<String> {
Log.i("zhuliyuan", "从内存获取数据")
if (!TextUtils.isEmpty(memory)) {
it.onNext(memory!!)
}
it.onComplete()
}
val diskObservable = Observable.create<String> {
Log.i("zhuliyuan", <