1.Rxjava1中的背压
Rxjava2中有这么一个被观察者Flowable,同样作为被观察者,它和Observable有什么区别呢,在Rxjava2中,Observable不再支持背压,而新增的Flowable支持背压,何为背压,就是上游发送事件的速度大于下游处理事件的速度所产生的现象。
我们来看个例子,先把rxjava切换到rxjava1.0:
implementation 'io.reactivex:rxjava:1.1.6'
implementation 'io.reactivex:rxandroid:1.2.1'
然后执行如下代码:
//被观察者在主线程中,每1ms发送一个事件
Observable.interval(1, TimeUnit.MILLISECONDS)
//观察者每1s才处理一个事件
.subscribe(new Action1() {
@Override
public void call(Long aLong) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Log.w("tag", "---->" + aLong);
}
});
执行结果如下:
image.png
我特?说好的背压呢,说好的异常呢,不要慌,因为上面的代码是同步的情况,都是运行在祝线程的,所以同步的情况下,被观察者每发送一个事件,观察者就会处理一个事件,等观察者处理完当前事件后,被观察者才会继续发送事件,两者分工明确,恩爱和睦,不存在发送速度不一致的情况。
下面我们来看下异步的情况:
//被观察者在主线程中,每1ms发送一个事件
Observable.interval(1, TimeUnit.MILLISECONDS)
.observeOn(Schedulers.newThread())
//观察者在子线程中每1s处理一个事件
.subscribe(new Action1() {
@Override
public void call(Long aLong) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Log.w("tag", "---->" + aLong);
}
});
运行后就会出现如下异常:
image.png
出现了背压的情况,抛出了MissingBackpressureException异常,异步情况下被观察者发送事件是比较暴力的,一次性全部发完,放在缓存池,然后观察者一条条慢慢去处理,发送过快就会出现背压的情况.
背压产生的条件:必须是异步的场景下才会出现,即被观察者和观察者处于不同的线程中。
rxjava1中默认的缓存池大小是16,当事件超过就会出现MissingBackpressureException,看如下例子:
Observable.create(new Observable.OnSubscribe() {
@Override
public void call(Subscriber super String> subscriber) {
for (int i = 0; i < 17; i++) {
Log.w("tag", "send ----> i = " + i);
subscriber.onNext("i = "+i);
}
}
})
.subscribeOn(Schedulers.newThread())
//将观察者的工作放在新线程环境中
.observeOn(Schedulers.newThread())
//观察者处理每1000ms才处理一个事件
.subscribe(new Action1() {
@Override
public void call(String value) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Log.w("tag", "---->" + value);
}
});
你看: