兩個異常

項(xiàng)目中用OKhttp,在BaseActivity的onDestory方法中會取消當(dāng)前activity的請求,但是測試發(fā)現(xiàn)有的時候請求還是沒有取消

情況一

在Activity的請求成功回調(diào)中直接了下面代碼

        FragmentManager fragmentManager = getSupportFragmentManager();
        FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
        if (!fragment.isAdded()) {
            fragmentTransaction.add(R.id.drawer_content, fragment, CATEGORY_FRAGMENT);
        } else {
            fragmentTransaction.show(fragment);
        }
        fragmentTransaction.commitAllowingStateLoss();

當(dāng)Activity退出的時候,雖然在BaseActivity中寫了相應(yīng)的取消請求的方法,但是還是會報(bào)下面異常:

W: java.lang.IllegalStateException: Activity has been destroyed
W:     at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1864)
W:     at android.support.v4.app.BackStackRecord.commitInternal(BackStackRecord.java:650)
W:     at android.support.v4.app.BackStackRecord.commitAllowingStateLoss(BackStackRecord.java:614)
W:     at 包名.GoodsSearchResultActivity.initFilterList(GoodsSearchResultActivity.java:835)
W:     at 包名.GoodsSearchResultActivity$14.onSuccess(GoodsSearchResultActivity.java:711)
W:     at 包名.GoodsSearchResultActivity$14.onSuccess(GoodsSearchResultActivity.java:683)
W:     at 包名.GearBestHttpClient$6$2.run(GearBestHttpClient.java:612)
W:     at android.os.Handler.handleCallback(Handler.java:789)
W:     at android.os.Handler.dispatchMessage(Handler.java:98)
W:     at android.os.Looper.loop(Looper.java:164)
W:     at android.app.ActivityThread.main(ActivityThread.java:6541)
W:     at java.lang.reflect.Method.invoke(Native Method)
W:     at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
W:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
W: Heartbeat timeout, GCM connection reset 0

情況二

對比情況一調(diào)用下面代碼

        FragmentManager fragmentManager = getSupportFragmentManager();
        FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
        if (!fragment.isAdded()) {
            fragmentTransaction.add(R.id.drawer_content, fragment, CATEGORY_FRAGMENT);
        } else {
            fragmentTransaction.show(fragment);
        }
        fragmentTransaction.commit();

則會報(bào)下面異常

W: java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState
W:     at android.support.v4.app.FragmentManagerImpl.checkStateLoss(FragmentManager.java:1842)
W:     at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1860)
W:     at android.support.v4.app.BackStackRecord.commitInternal(BackStackRecord.java:650)
W:     at android.support.v4.app.BackStackRecord.commit(BackStackRecord.java:609)
W:     at 包名.GoodsSearchResultActivity.initFilterList(GoodsSearchResultActivity.java:835)
W:     at 包名.GoodsSearchResultActivity$14.onSuccess(GoodsSearchResultActivity.java:711)
W:     at 包名.GoodsSearchResultActivity$14.onSuccess(GoodsSearchResultActivity.java:683)
W:     at 包名.GearBestHttpClient$6$2.run(GearBestHttpClient.java:612)
W:     at android.os.Handler.handleCallback(Handler.java:789)
W:     at android.os.Handler.dispatchMessage(Handler.java:98)
W:     at android.os.Looper.loop(Looper.java:164)
W:     at android.app.ActivityThread.main(ActivityThread.java:6541)
W:     at java.lang.reflect.Method.invoke(Native Method)
W:     at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
W:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)

解決

穩(wěn)定一點(diǎn)還是請求回調(diào)的時候判斷一下

if(isFinishing){
    return;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容