Android更新问题
- 问题描述:
在Android更新包下载成功后,安装替换取消,如果取消了,再次运行后
dialog弹出的context丢失,出现以下错误:
06-02 15:53:05.010: E/CrashHandler(23076): android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@42e6c540 is not valid; is your activity running?
06-02 15:53:05.010: E/CrashHandler(23076): at android.view.ViewRootImpl.setView(ViewRootImpl.java:637)
06-02 15:53:05.010: E/CrashHandler(23076): at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:261)
06-02 15:53:05.010: E/CrashHandler(23076): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
06-02 15:53:05.010: E/CrashHandler(23076): at android.app.Dialog.show(Dialog.java:290)
06-02 15:53:05.010: E/CrashHandler(23076): at com.deppon.express.common.dialog.CustomProgressDialog.show(CustomProgressDialog.java:173)
06-02 15:53:05.010: E/CrashHandler(23076): at com.deppon.express.login.update.service.SmartPgmVerUpdateManager$1.checkUpdateCompleted(SmartPgmVerUpdateManager.java:964)
06-02 15:53:05.010: E/CrashHandler(23076): at com.deppon.express.login.update.service.SmartPgmVerUpdateManager$2.handleMessage(SmartPgmVerUpdateManager.java:215)
06-02 15:53:05.010: E/CrashHandler(23076): at android.os.Handler.dispatchMessage(Handler.java:110)
06-02 15:53:05.010: E/CrashHandler(23076): at android.os.Looper.loop(Looper.java:193)
06-02 15:53:05.010: E/CrashHandler(23076): at android.app.ActivityThread.main(ActivityThread.java:5292)
06-02 15:53:05.010: E/CrashHandler(23076): at java.lang.reflect.Method.invokeNative(Native Method)
06-02 15:53:05.010: E/CrashHandler(23076): at java.lang.reflect.Method.invoke(Method.java:515)
06-02 15:53:05.010: E/CrashHandler(23076): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:825)
06-02 15:53:05.010: E/CrashHandler(23076): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:641)
06-02 15:53:05.010: E/CrashHandler(23076): at dalvik.system.NativeStart.main(Native Method)
原因
再次启动后的dialog依然持有上次启动的Activity的Context,而上次Activity的Context会被销毁,所以造成dialog的Context丢失,出现以上问题解决办法
在进行更新安装时,把本次启动的旧版本应用kill掉,完美解决
代码如下:
Intent i = new Intent(Intent.ACTION_VIEW);
i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
i.setDataAndType(Uri.parse("file://" + filePath),
"application/vnd.android.package-archive");
activity.startActivity(i);
//下面这句是关键
android.os.Process.killProcess(android.os.Process.myPid());