任何人都可以向我解释为什么会出现这种错误,甚至更好地解决这个问题?我无法重现它。这是1000次中发生的错误之一。
后台:用户正在尝试登录,正在显示进度对话框,在异步任务中发送http请求,进程对话框被取消。发生错误,app FC。
LoginActivity.java
255: private void dismissProgress() {
256: if (mProgress != null) {
257: mProgress.dismiss();
258: mProgress = null;
259: }
260: }
java.lang.IllegalArgumentException: View not attached to window manager
at android.view.WindowManagerImpl.findViewLocked(WindowManagerImpl.java:391)
at android.view.WindowManagerImpl.removeView(WindowManagerImpl.java:236)
at android.view.Window$LocalWindowManager.removeView(Window.java:432)
at android.app.Dialog.dismissDialog(Dialog.java:278)
at android.app.Dialog.access$000(Dialog.java:71)
at android.app.Dialog$1.run(Dialog.java:111)
at android.app.Dialog.dismiss(Dialog.java:268)
at se.magpern.LoginActivity.dismissProgress(LoginActivity.java:257)
at se.magpern.LoginActivity.access$5(LoginActivity.java:255)
at se.magpern.LoginActivity$DoTheLogin.onPostExecute(LoginActivity.java:293)
at se.magpern.LoginActivity$DoTheLogin.onPostExecute(LoginActivity.java:1)
at android.os.AsyncTask.finish(AsyncTask.java:417)
at android.os.AsyncTask.access$300(AsyncTask.java:127)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:144)
at android.app.ActivityThread.main(ActivityThread.java:4937)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
答案 0 :(得分:15)
如果用户关闭视图(例如,可以退出的对话框),或者用户在任务运行时切换到其他活动,则会发生这种情况。您应该认真考虑使用Android的activity-native对话框显示/解除,而不是尝试自己保留对视图的引用。但是如果您自己处理它,您可能想要在尝试关闭对话框之前使用对话框的isShowing()
方法检查对话框是否实际显示。
答案 1 :(得分:6)
我已经看到,当潜在的更新进入已完全或部分解散的进度对话框时会发生这种情况。用户在尝试解除视图并且已经从窗口断开连接的同时请求解雇,反之亦然。
在单击按钮时解除进度窗口的代码与以另一种方式解除进度窗口的代码之间存在竞争条件。最有可能寻找这种竞争条件的地方是你将解雇窗口的请求放到视图线程(按钮处理程序或代码回调)上。