CompositeDisposable.clear导致OkHttp抛出java.lang.IllegalStateException:不平衡的输入/退出 [英] CompositeDisposable.clear causes OkHttp to throw java.lang.IllegalStateException: Unbalanced enter/exit

查看:914
本文介绍了CompositeDisposable.clear导致OkHttp抛出java.lang.IllegalStateException:不平衡的输入/退出的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

所以我有一个使用OkHttp的简单http请求.我使用Android上的RxJava进行此操作.我将此RxJava调用添加到CompositeDisposable中,然后在onStop上清除该调用.由于某种原因在下面触发了此异常.我不太确定如何解决它.

So I have a simple http request using OkHttp. I do this with RxJava on Android. I add this RxJava call to a CompositeDisposable that I then clear on onStop. For some reason that is triggering this exception below. I'm a little unsure about how to fix it.

Caused by java.lang.IllegalStateException: Unbalanced enter/exit
       at okio.AsyncTimeout.enter(AsyncTimeout.java:73)
       at okio.AsyncTimeout$2.read(AsyncTimeout.java:235)
       at okio.RealBufferedSource.read(RealBufferedSource.java:47)
       at okhttp3.internal.http1.Http1Codec$AbstractSource.read(Http1Codec.java:363)
       at okhttp3.internal.http1.Http1Codec$FixedLengthSource.read(Http1Codec.java:407)
       at okio.RealBufferedSource.read(RealBufferedSource.java:47)
       at okhttp3.internal.cache.CacheInterceptor$1.read(CacheInterceptor.java:174)
       at okhttp3.internal.Util.skipAll(Util.java:175)
       at okhttp3.internal.Util.discard(Util.java:157)
       at okhttp3.internal.cache.CacheInterceptor$1.close(CacheInterceptor.java:202)
       at okio.RealBufferedSource.close(RealBufferedSource.java:469)
       at okio.RealBufferedSource$1.close(RealBufferedSource.java:453)
       at java.nio.channels.Channels$ReadableByteChannelImpl.implCloseChannel(Channels.java:255)
       at java.nio.channels.spi.AbstractInterruptibleChannel$1.interrupt(AbstractInterruptibleChannel.java:166)
       at java.lang.Thread.interrupt(Thread.java:957)
       at java.util.concurrent.FutureTask.cancel(FutureTask.java:146)
       at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.cancel(ScheduledThreadPoolExecutor.java:258)
       at io.reactivex.internal.schedulers.ScheduledRunnable.dispose(ScheduledRunnable.java:107)
       at io.reactivex.disposables.CompositeDisposable.dispose(CompositeDisposable.java:217)
       at io.reactivex.disposables.CompositeDisposable.dispose(CompositeDisposable.java:80)
       at io.reactivex.internal.schedulers.IoScheduler$EventLoopWorker.dispose(IoScheduler.java:210)
       at io.reactivex.Scheduler$DisposeTask.dispose(Scheduler.java:464)
       at io.reactivex.internal.disposables.DisposableHelper.dispose(DisposableHelper.java:125)
       at io.reactivex.internal.operators.observable.ObservableSubscribeOn$SubscribeOnObserver.dispose(ObservableSubscribeOn.java:74)
       at io.reactivex.internal.operators.observable.ObservableObserveOn$ObserveOnObserver.dispose(ObservableObserveOn.java:146)
       at io.reactivex.internal.disposables.DisposableHelper.dispose(DisposableHelper.java:125)
       at io.reactivex.observers.DisposableObserver.dispose(DisposableObserver.java:91)
       at io.reactivex.disposables.CompositeDisposable.dispose(CompositeDisposable.java:217)
       at io.reactivex.disposables.CompositeDisposable.clear(CompositeDisposable.java:183)
       at MyActivity.onStop(MyActivity.java:320)
       at android.app.Instrumentation.callActivityOnStop(Instrumentation.java:1297)
       at android.app.Activity.performStop(Activity.java:7159)
       at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:4625)
       at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:4691)
       at android.app.ActivityThread.-wrap7(ActivityThread.java)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1718)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:154)
       at android.app.ActivityThread.main(ActivityThread.java:6732)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1520)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1410)

代码基本上是这样的:

Observable<Stuff> observable = Observable.create(new ObservableOnSubscribe<Stuff>() {
            @Override
            public void subscribe(@NonNull ObservableEmitter<Stuff> e) throws Exception {

           //do OkHttp stuff, call onNext(stuff). 

            }
        })
        .subscribeOn(Schedulers.io())
        .observeOn(AndroidSchedulers.mainThread());
        DisposableObserver<Stuff> disposableObserver = observable
            .subscribeWith(new DisposableObserver<Stuff>() {......});

        disposables.add(disposableObserver);

推荐答案

某些Android VM中存在一个错误,无法与新的D8编译器交互.

Theres a bug in some Android VMs that interacts poorly with the new D8 compiler.

https://github.com/square/okhttp/issues/3641 #issuecomment-370717021

Google最近改进了D8,以避免触发该错误.

Google has recently improved D8 to avoid triggering the bug.

这篇关于CompositeDisposable.clear导致OkHttp抛出java.lang.IllegalStateException:不平衡的输入/退出的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆