最近项目有一个弹dialog的异常,但是在本地是没有发现问题的,上线之后在线上崩溃发现了这个异常,但是不是很多,我的出现的问题就是:
Fatal Exception: android.view.WindowManager$BadTokenException Unable to add window -- token android.os.BinderProxy@f377468 is not valid; is your activity running? Raw Text | |
---|---|
android.view.ViewRootImpl.setView (ViewRootImpl.java:780) | |
android.view.WindowManagerGlobal.addView (WindowManagerGlobal.java:371) | |
android.view.WindowManagerImpl.addView (WindowManagerImpl.java:93) | |
android.app.Dialog.show (Dialog.java:352) | |
com.androapplite.shadowsocks.utils.DialogUtils.showGameGetTimeDialog (DialogUtils.java:67) | |
com.androapplite.shadowsocks.activity.LuckRotateActivity$2.endAnimation (LuckRotateActivity.java:268) | |
com.androapplite.shadowsocks.luckPan.RotatePan$2.onAnimationEnd (RotatePan.java:332) | |
android.animation.Animator$AnimatorListener.onAnimationEnd (Animator.java:552) | |
android.animation.ValueAnimator.endAnimation (ValueAnimator.java:1209) | |
android.animation.ValueAnimator.doAnimationFrame (ValueAnimator.java:1449) | |
android.animation.AnimationHandler.doAnimationFrame (AnimationHandler.java:146) | |
android.animation.AnimationHandler.-wrap2 (Unknown Source) | |
android.animation.AnimationHandler$1.doFrame (AnimationHandler.java:54) | |
android.view.Choreographer$CallbackRecord.run (Choreographer.java:919) | |
android.view.Choreographer.doCallbacks (Choreographer.java:729) | |
android.view.Choreographer.doFrame (Choreographer.java:661) | |
android.view.Choreographer$FrameDisplayEventReceiver.run (Choreographer.java:907) | |
android.os.Handler.handleCallback (Handler.java:790) | |
android.os.Handler.dispatchMessage (Handler.java:99) | |
android.os.Looper.loop (Looper.java:164) | |
android.app.ActivityThread.main (ActivityThread.java:6524) | |
java.lang.reflect.Method.invoke (Method.java) | |
com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:451) | |
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:888) |
报错后台给的说明是:
This crash is usually caused by your app trying to display a dialog using a previously-finished Activity as a context. For example, this can happen if an Activity triggers an AsyncTask that tries to display a dialog when it is finished, but the user navigates back from the Activity before the task is completed.
大体翻译意思:这个崩溃通常是由你的应用程序试图用一个之前完成的活动作为上下文来显示一个对话框。例如,如果一个活动触发一个AsyncTask,当它完成时试图显示一个对话框,但是用户在任务完成之前从活动中导航回来,就会发生这种情况。
总结出来的问题就是当你的dialog弹出的时候你所依附的Activity销毁了,所有弹出没有依附的dialog会报错,只需一句代码就能搞定此错误,加一句判断
if(!((Activity)context).isFinishing()){
dialog.show();
}
在弹出弹窗的时候在你所依附的地方加一句你当前的Activity有没有被finish了就可以了。