网络请求有个问题就是取消操作。
在Rxjava1中,调用subscribe之后会返回Subscription,然后利用CompositeSubscription进行统一管理。
在Rxjava2中,调用subscribe之后,返回的则是Disposable,Disposable同样用CompositeDisposable进行统一管理。
在Rxjava1中,我们继承Subscriber,可以这么写。
class MySubscriber<T> extends Subscriber<T> { @Override
public void onStart() {
//do sth
} @Override
public void onCompleted() {
//do sth
} @Override
public void onError(Throwable e) {
//do sth
} @Override
public void onNext(T response) {
//do sth
}
}
而在Rxjava2中,我们则要继承ResourceSubscriber,写法也有些修改
class MySubscriber<T> extends ResourceSubscriber<T> { @Override
public void onStart() {
super.onStart();//这里要特别注意,不能忽略,我就因为没注意到这个,吃了不少的亏
} @Override
public void onComplete() {
} @Override
public void onError(Throwable e) {
} @Override
public void onNext(T response) {
}
}
然后要注意的就是FlowableOnSubscribe这个类,一般来说我们会这么写:
Flowable.create(new FlowableOnSubscribe<T>() {
@Override
public void subscribe(final FlowableEmitter<T> e) throws Exception {
try {
Response<T> response = call.execute();
e.onNext(response.body());
e.onComplete();
} catch (Exception exception) {
e.onError(exception);
e.onComplete();
}
}
}, BackpressureStrategy.BUFFER);
但这样子就会有个错误,上面提到了CompositeDisposable这个要管理Disposable,如果我们取消了操作,那就极有可能会发生,InterruptedException异常,因为call还在继续执行,它执行完之后,就会调用 e.onNext(response.body());之类的方法,继而抛出异常,解决方案就是把上面的改写一下:
Flowable.create(new FlowableOnSubscribe<T>() {
@Override
public void subscribe(final FlowableEmitter<T> e) throws Exception {
//设置取消监听
e.setCancellable(new Cancellable() {
@Override
public void cancel() throws Exception {
if (!call.isCanceled()) {
call.cancel();
}
}
});
try {
Response<T> response = call.execute();
if (!e.isCancelled()) {
e.onNext(response.body());
e.onComplete();
}
} catch (Exception exception) {
if (!e.isCancelled()) {
e.onError(exception);
e.onComplete();
}
}
}
}, BackpressureStrategy.BUFFER);
加入了取消监听以及取消判断就ok了,这样子的做法比Rxjava1要好,Rxjava1即使取消了订阅,请求却还会继续跑,这就不会了