使用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...

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

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

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

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

企业或公司为什么要做网站?拥有企业网站的优势在哪?1

当今商界的竞争如狮虎争食,因此,只有让自己变得强大起来,我们才能争得一块属于自己的肉。 在八十年代,一个没有电话的企业就是落伍;在九十年代,一个没有传真的企业就是掉队;而如今,在这个电...
  • gltywl
  • gltywl
  • 2011年05月29日 17:51
  • 1

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

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

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

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

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

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

java.lang.NoClassDefFoundError: Failed resolution of: Lokhttp3/internal/Platform

使用OKHttp3作为网络访问的框架时,可能要经常查看日志,这时我们可以引入logging-interceptor拦截器。如下: compile 'com.squareup.okhttp3:loggi...

使用okhttp3出现java.lang.NoClassDefFoundError: okio.Buffer的错误怎么办?

使用okhttp3出现java.lang.NoClassDefFoundError: okio.Buffer的错误怎么办?okhttp的菜鸟,今天刚开始接触。问题描述/提示:按照okhttp的get和...

RxJava里doOnNext的使用和线程处理

doOnNext的使用我对doOnNext的使用是存在疑惑的,按照官方文档 The doOnNext operator is much like doOnEach(Action1) except ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用retrofit+rxjava报java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread
举报原因:
原因补充:

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