首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >异步RxJava订阅仍抛出NetworkOnMainThreadException

异步RxJava订阅仍抛出NetworkOnMainThreadException
EN

Stack Overflow用户
提问于 2016-08-05 09:40:35
回答 1查看 158关注 0票数 0

所以,在看了这里的其他答案之后,解决了同样的问题,看起来解决方案不起作用。这是我得到的错误。我在newThread()上实现了RxJava,在mainThread()上实现了观察者。

所以我的第一个观察点是发射一个Observable>。我使用flatMapObservable对其进行迭代,并使用每个整数来获得单个新闻条目作为可观察值。

查看我的Http日志,我得到了整数列表和第一条新闻。那么我就会得到一个错误。

任何帮助都将不胜感激。

代码语言:javascript
运行
复制
mMainProvider.getNewestHackerStories()
            .subscribeOn(Schedulers.newThread())
            .observeOn(AndroidSchedulers.mainThread())
            .doOnError(Throwable::printStackTrace)
            .flatMapIterable(ids -> ids)
            .flatMap(id -> mMainProvider.getHackerNewsItem(id))
            .subscribe(hackerNewsItem -> newStoryList.add(hackerNewsItem));

代码语言:javascript
运行
复制
17-12017/com.androidtitan.magicmirror W/System.err: android.os.NetworkOnMainThreadException
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1273)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at com.android.org.conscrypt.OpenSSLSocketImpl.shutdownAndFreeSslNative(OpenSSLSocketImpl.java:1237)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at com.android.org.conscrypt.OpenSSLSocketImpl.close(OpenSSLSocketImpl.java:1232)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.internal.Util.closeQuietly(Util.java:105)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.internal.http.StreamAllocation.deallocate(StreamAllocation.java:259)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.internal.http.StreamAllocation.streamFailed(StreamAllocation.java:306)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.internal.http.HttpEngine.close(HttpEngine.java:478)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.RealCall.getResponse(RealCall.java:273)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:201)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.logging.HttpLoggingInterceptor.intercept(HttpLoggingInterceptor.java:212)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:190)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:163)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at okhttp3.RealCall.execute(RealCall.java:57)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at retrofit2.OkHttpCall.execute(OkHttpCall.java:174)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$RequestArbiter.request(RxJavaCallAdapterFactory.java:171)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.Subscriber.setProducer(Subscriber.java:211)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.Subscriber.setProducer(Subscriber.java:205)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$CallOnSubscribe.call(RxJavaCallAdapterFactory.java:152)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$CallOnSubscribe.call(RxJavaCallAdapterFactory.java:138)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:50)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.Observable.unsafeSubscribe(Observable.java:8666)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OperatorMerge$MergeSubscriber.onNext(OperatorMerge.java:250)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OperatorMerge$MergeSubscriber.onNext(OperatorMerge.java:147)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OperatorMap$MapSubscriber.onNext(OperatorMap.java:74)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OnSubscribeFlattenIterable$FlattenIterableSubscriber.drain(OnSubscribeFlattenIterable.java:239)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OnSubscribeFlattenIterable$FlattenIterableSubscriber.onNext(OnSubscribeFlattenIterable.java:130)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.internal.operators.OperatorObserveOn$ObserveOnSubscriber.call(OperatorObserveOn.java:227)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at rx.android.schedulers.LooperScheduler$ScheduledAction.run(LooperScheduler.java:107)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at android.os.Handler.handleCallback(Handler.java:739)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:95)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at android.os.Looper.loop(Looper.java:158)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:7224)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
08-04 21:27:16.766 12017-12017/com.androidtitan.magicmirror W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

EN

回答 1

Stack Overflow用户

发布于 2016-08-05 16:05:49

observeOn(AndroidSchedulers.mainThread())之后的所有东西都将在主线程上运行。我认为mMainProvider.getHackerNewsItem是一个网络调用,所以您应该将observeOn行移到subscribe之前。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38779851

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档