RxJava操作符实践:9_反压操作之3_onBackpressureLatest

一、描述

当Observable发出的元素的速度比订阅者消化得要快,订阅者会接收Observable最新发出的item进行处理。

二、示意图

onBackpressureLatest

三、示例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Observable.interval(1, TimeUnit.MILLISECONDS)
.onBackpressureLatest()
.observeOn(Schedulers.newThread())
.subscribe(new Subscriber<Long>() {
@Override
public void onCompleted() {
System.out.println("onCompleted.");
}

@Override
public void onError(Throwable e) {
System.out.println("onError: " + e.getMessage());
}

@Override
public void onNext(Long aLong) {
System.out.println("onNext: " + aLong);
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});

四、运行结果

1
2
3
4
5
6
7
8
9
10
onNext: 0
onNext: 1
onNext: 2
...
onNext: 15
onNext: 1607
onNext: 1608
...
onNext: 1622
...

五、参考资料

ReactiveX官方文档

ReactiveX文档中文翻译

RxJava 教程第四部分:并发 之数据流发射太快如何办

RxJava中backpressure这个概念的理解

PS:欢迎关注 SherlockShi 个人博客

感谢你的支持,让我继续努力分享有用的技术和知识点!