使用retrofit+rxjava报java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread

原创 2016年08月29日 17:15:39

引言:如果还没有接触retrofit+rxjava的同学赶紧学起来吧!真的炒鸡好用辣。。。

好了,言归正传。最近才接触的retrofit和rxjava,所以在实践过程中会遇到一些之前没有遇到过的
问题,昨天因为第三方包的原因搞了一整天才解决,所以今天就来给大家分享一下。
首先,我导入的包是:

compile 'com.squareup.retrofit2:retrofit:2.0.2'
compile 'com.squareup.retrofit2:converter-gson:2.0.2'
compile 'com.squareup.retrofit2:adapter-rxjava:2.0.2'
compile 'io.reactivex:rxjava:1.1.0'
compile 'com.squareup.okhttp3:logging-interceptor:3.1.2'
compile 'com.squareup.okhttp3:okhttp:3.4.1' compile 'com.google.code.gson:gson:2.6.2'

然后在声明retrofit的时候我设置了一下log拦截器

addInterceptor(new HttpLoggingInterceptor()
.setLevel(HttpLoggingInterceptor.Level.BODY));

然后运行的时候就懵逼了

E/AndroidRuntime: FATAL EXCEPTION: RxCachedThreadScheduler-1
Process: com.jack.mc.cyg.retrofittestproject, PID: 30089
    java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread.
    ..........(还有很多错误日志)
     Caused by: java.lang.NoClassDefFoundError: okhttp3.internal.Platform

在这里我们不用去关心其他的错误日志,只需要看什么异常,看造成异常的原因就可以了。昨天看到这个的时候我就很奇怪,明明导了okhttp3这个包啊!为什么会报错呢,然后我就习惯性的build项目了,后来发现还是不行,然后我就在网上疯狂的下载retrofit的源码,后来我发现大多数人在声明retrofit的时候都没有设置log拦截器,然后我就跟风,把log拦截器给干掉了,后来发现竟然可以正常运行了,然后我又懵逼了,这跟log拦截器有什么关系啊???然后我就试着去谷歌那个错误,结果在stackoverflow上找到了发生错误的原因,是说导入的包版本不匹配,这么一说,再来看之前导入的包,哪些包不匹配呢,我估计大家都猜出来了,肯定是有log拦截器的包啊!然后我就又重新导入okhttp3和logging-interceptor这两个包:

compile 'com.squareup.retrofit2:retrofit:2.0.2'
compile 'com.squareup.retrofit2:converter-gson:2.0.2'
compile 'com.squareup.retrofit2:adapter-rxjava:2.0.2'
compile 'io.reactivex:rxjava:1.1.0'
compile 'com.squareup.okhttp3:okhttp:3.3.1'
compile 'com.squareup.okhttp3:logging-interceptor:3.3.1'
compile 'com.google.code.gson:gson:2.6.2'

然后重新运行,bingo,完美

在此附上查阅的网站网址:

点我查阅

版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

RxJava:java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread.

在使用RxJava的时候,突然之间就出现了一个问题:java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worke...

使用retrofit与Rxjava结合出的错误:java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker

使用Retrofit与Rxjava报的错误:Process: com.example.john.retrofit2, PID: 14741 ...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

RxJava+Retrofit+OkHttp 懒人方式使用一

Retrofit+Rxjava+okhttp 懒人方式使用一背景之前学习完Retrofit+Rxjava之后写了一篇关于封装的博客,发出后受到大家的关注以及使用,由于不断的完善之前的项目,所以决定把最...

okhttp Fatal Exception thrown on Scheduler.Worker thread问题解决

我在项目里面同时使用了以下两个类库: compile 'com.squareup.okhttp3:logging-interceptor:3.3.1' compile 'com.squareup....

RxJava+Retrofit+OkHttp深入浅出-终极封装七(异常处理)

Rxjava+ReTrofit+okHttp深入浅出-终极封装七(异常处理)背景在前面Rxjava+ReTrofit+okHttp深入浅出-终极封装专栏我们已经全面的封装了一套可以投入实战的框架,最近...

retrofit+Rxjava使用出现错误:Fatal Exception thrown on Scheduler.Worker thread.

错误信息:java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread.

RxJava+Retrofit+OkHttp深入浅出-终极封装三(文件上传)

RxJava+Retrofit+OkHttp封装三(文件上传带进度)背景在实际运用中上传是一个必不可少的功能,所以我们在封装二的基础上加入上传的功能,同时需要附带上传进度!效果实现1.定义servic...

开发中遇到的问题--java.lang.IllegalStateException

在实际开发中经常会遇到java.lang.IllegalStateException的异常。下面是我所遇到的java.lang.IllegalStateException的解决方法: 1.  在AP...

RxJava+Retrofit+OkHttp深入浅出-终极封装二(网络请求)

Rxjava+ReTrofit+okHttp背景:    学习Rxjava+Retrofit+okhttp已经一段时间了,发现确实很强大,但是使用起来稍微有点麻烦,在工作中重复的代码太多,所以决定对h...

RxJava+Retrofit+OkHttp深入浅出-mvp(使用篇)

RxJava+Retrofit+OkHttp深入浅出-mvp(使用篇)背景RxJava+Retrofit+OkHttp封装系列也基本完成了,功能无太大迭代的需要,但是最近QQ群中有兄弟问如何结合mvp...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)