Я использую Retrofit и RxJava для выполнения некоторых фоновых задач. Код выглядит так:
public class MyLoader{
public Observable<MyData> getMyData(){
return setupHelper().flatMap(new Func1<MyHelper, Observable<MyData>>() {
@Override
public Observable<MyData> call(MyHelper myHelper) {
return queryData(myHelper);
}
});
}
private Observable<MyData> queryData(MyHelper myHelper){
...
}
private Observable<MyHelper> setupHelper(){
return Observable.create(new Observable.OnSubscribe<MyHelper>() {
@Override
public void call(final Subscriber<? super MyHelper> subscriber) {
try{
MyHelper helper = makeRetrofitCall();//Using Retrofit blocking call to get some data
subscriber.onNext(helper);
subscriber.onCompleted();
}catch(RetrofitError e){
subscriber.onError(e)
}
}
}
}
}
Это не удается с RetrofitError из-за исключения NetworkOnMainThread
в этой строке:
MyHelper helper = makeRetrofitCall();//Using Retrofit blocking call to get some data
Подписка на мой Observable:
myLoader.getMyData()
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Subscriber<MyData>() {
@Override
public void onCompleted() {
}
@Override
public void onError(Throwable e) {
}
@Override
public void onNext(MyData inventory) {
}
});
Согласно документации Rx, flatMap
не работает ни с одним фоновым потоком. Мой вопрос заключается в том, как мне убедиться, что весь метод getMyData()
работает в фоновом режиме.
.subscribeOn(Schedulers.io())
вsetupHelper
? - person akarnokd   schedule 03.09.2015.subscribeOn()
во второй наблюдаемый? - person Juan Saravia   schedule 09.12.2015Observable
напрямую, вам не нужно оборачивать вызов таким образом. В противном случае вы также можете просто использоватьObservable.fromCallable(this::makeRetrofitCall)
(при условии, что у вас есть ссылки на функции либо через Java 8, либо через retrolambda). - person njzk2   schedule 08.05.2017