Android 在OkHttp上输入/输出不平衡

Android 在OkHttp上输入/输出不平衡,android,rx-java,okhttp,rx-android,okhttp3,Android,Rx Java,Okhttp,Rx Android,Okhttp3,因此,我经常会遇到一个异常,即java.lang.IllegalStateException:incremented/exit,当我的活动的onStop调用disposables.clear()时就会发生这种情况 有人告诉我这是一个D8错误,但我现在使用的是最新的D8,或者Android Studio 3.1.3的最新版本,而且它仍然在发生 我还被告知要想办法调用call.cancel() 所以我的问题是,我怎样才能使一次性的.clear()调用调用.cancel() 这是一个例外: Cause

因此,我经常会遇到一个异常,即
java.lang.IllegalStateException:incremented/exit
,当我的活动的
onStop
调用
disposables.clear()
时就会发生这种情况

有人告诉我这是一个D8错误,但我现在使用的是最新的D8,或者Android Studio 3.1.3的最新版本,而且它仍然在发生

我还被告知要想办法调用
call.cancel()

所以我的问题是,我怎样才能使
一次性的.clear()
调用
调用.cancel()

这是一个例外:

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$ChunkedSource.read(Http1Codec.java:453)
    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.io.BufferedInputStream.close(BufferedInputStream.java:472)
    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:956)
    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:321)
    at android.app.Instrumentation.callActivityOnStop(Instrumentation.java:1289)
    at android.app.Activity.performStop(Activity.java:6841)
    at android.app.ActivityThread.performStopActivityInner(ActivityThread.java:3947)
    at android.app.ActivityThread.handleStopActivity(ActivityThread.java:4005)
    at android.app.ActivityThread.-wrap25(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1561)
    at android.os.Handler.dispatchMessage(Handler.java:110)
    at android.os.Looper.loop(Looper.java:203)
    at android.app.ActivityThread.main(ActivityThread.java:6251)
    at java.lang.reflect.Method.invoke(Method.java)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1063)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:924)
代码基本上是这样的:

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);
Observable-Observable=Observable.create(newobservableOnSubscribe()){
@凌驾
public void subscribe(@NonNull observeiemitter e)引发异常{
//执行OkHttp任务,调用onNext(任务)。
}
})
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread());
DisposableObserver DisposableObserver=可观测
.subscribowith(新的可处置观察员(){……});
可处置。添加(可处置观察员);
e.setCancelable(新的可取消(){
@凌驾
public void cancel()引发异常{
call.cancel();
}
});
调用
subscribe(@NonNull observeiemitter e)
方法中发射器的
setcancelable
,当
observeable
被释放时,将执行此
cancelable

我很好奇如何调用
close
方法,在我的情况下,中断线程永远不会调用
源代码的
close
方法,我必须手动调用
call.cancel()
来中断阻塞读取