运行集成的三方应用时,出现报错,错误信息如下:
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: FATAL EXCEPTION: main
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: Process: com.turkcell.akademi, PID: 11590
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: java.lang.IllegalArgumentException: View=DecorView@d42eb8a[] not attached to window manager
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.view.WindowManagerGlobal.findViewLocked(WindowManagerGlobal.java:491)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.view.WindowManagerGlobal.removeView(WindowManagerGlobal.java:397)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.view.WindowManagerImpl.removeViewImmediate(WindowManagerImpl.java:124)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.app.Dialog.dismissDialog(Dialog.java:371)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.app.Dialog.dismiss(Dialog.java:354)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at com.turkcell.akademi.httpclient.NetworkManager$CallAddressPost.onPostExecute(NetworkManager.java:340)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at com.turkcell.akademi.httpclient.NetworkManager$CallAddressPost.onPostExecute(NetworkManager.java:277)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.os.AsyncTask.finish(AsyncTask.java:710)
10-09 14:49:30.204310 11590 11590 E AndroidRuntime: at android.os.AsyncTask.-wrap1(Unknown Source:0)
解释
报错的地方是dialog调用dismiss方法的时候。查找资料发现,如果在dialog显示期间,所依附的activity因为某种原因被销毁或者销毁后又重新启动了,后面dialog在dismiss的时候window manager进行检查,就会发现所依附的activity已经不存在,则会报java.lang.IllegalArgumentException:not attached to window manager
解决办法
在activity的destory方法中,判断dialog是否存在,若存在,则dismiss掉dialog,使dialog的生命周期与activity同步