Android应用重启
来源:互联网 发布:淘宝的铁观音 编辑:程序博客网 时间:2024/05/18 02:26
Android App Crash之后如何禁止Activity重启
针对Crash,Android默认的处理方式是,退出App、弹一个提示框。
这样的反馈难免有些暴力,还丑,我们需要更温和一点的提示,于是自定义UncatchExceptionHandler来截获处理Crash:
/** * 初始化 * * @param context */ public void init(Context context) { mContext = context; // 获取系统默认的UncaughtException处理器 mDefaultHandler = Thread.getDefaultUncaughtExceptionHandler(); // 设置该CrashHandler为程序的默认处理器 Thread.setDefaultUncaughtExceptionHandler(this); }/** * 当UncaughtException发生时会转入该函数来处理 */ @Override public void uncaughtException(Thread thread, Throwable ex) { if (!handleException(ex) && mDefaultHandler != null) { //如果用户没有处理则让系统默认的异常处理器来处理 mDefaultHandler.uncaughtException(thread, ex); } else { try { // 暂停3秒 Thread.sleep(3000); } catch (InterruptedException e) { Log.e(TAG, "error : ", e); } // 退出程序 android.os.Process.killProcess(android.os.Process.myPid()); System.exit(1); }}/** * 自定义错误处理,收集错误信息 发送错误报告等操作均在此完成. * * @param ex * @return true:如果处理了该异常信息;否则返回false. */ private boolean handleException(Throwable ex) { if (ex == null) { return false; } // 使用Toast来显示异常信息 new Thread() { @Override public void run() { Looper.prepare(); Toast.makeText(mContext, "程序出现异常,即将退出~", Toast.LENGTH_SHORT).show(); Looper.loop(); } }.start(); return true; }
但是问题也随之而来,自定义CrashHandler在退出App之后,会重启当前奔溃的Activity,如果奔溃的是LaunchActivity,那么会不断奔溃、重启、奔溃、重启……当然,也不用担心进入死循环(系统有做限制),但是体验极差。
于是对比Logcat日志:
系统默认HandlerI/ActivityManager( 1238): Process com.netease.mail.oneduobaohydrid.debug (pid 2780) has diedW/ActivityManager( 1238): Scheduling restart of crashed service com.netease.mail.oneduobaohydrid.debug/com.netease.mail.oneduobaohydrid.service.CommonService in 1000ms……I/ActivityManager( 1238): Start proc com.netease.mail.oneduobaohydrid.debug for service com.netease.mail.oneduobaohydrid.debug/com.netease.mail.oneduobaohydrid.service.CommonService: pid=2819 uid=10054 gids={50054, 9997, 1028, 1015, 3003} abi=x86
自定义HandlerI/ActivityManager( 1238): Process com.netease.mail.oneduobaohydrid.debug (pid 2993) has diedW/ActivityManager( 1238): Scheduling restart of crashed service com.netease.mail.oneduobaohydrid.debug/com.netease.mail.oneduobaohydrid.service.CommonService in 64000ms……I/ActivityManager( 1238): Start proc com.netease.mail.oneduobaohydrid.debug for activity com.netease.mail.oneduobaohydrid.debug/com.netease.mail.oneduobaohydrid.activity.MainActivity: pid=3030 uid=10054 gids={50054, 9997, 1028, 1015, 3003} abi=x86
相同点:Crash之后App对应的Process都被杀死,然后都安排重启Service。
不同点:自定义CrashHandler,存在一个由ActivityManager启动对应Activity的系统行为。
多放查阅资料,发现App Crash之后系统会重新启动Task栈顶的Activity,具体请自行google!
I know about Intent.FLAG_ACTIVITY_CLEAR_TOP, but as I understand that will only kill activities after they have been re-created.
解决方法是:在杀死App对应Process之前,结束掉Task栈中所有的Activity。
/** * 当UncaughtException发生时会转入该函数来处理 */ @Override public void uncaughtException(Thread thread, Throwable ex) { if (!handleException(ex) && mDefaultHandler != null) { //如果用户没有处理则让系统默认的异常处理器来处理 mDefaultHandler.uncaughtException(thread, ex); } else { try { // 暂停3秒 Thread.sleep(3000); } catch (InterruptedException e) { Log.e(TAG, "error : ", e); } // 结束所有Activity OneApplication.finishAllActivities(); // 退出程序 android.os.Process.killProcess(android.os.Process.myPid()); System.exit(1); }}
核心代码:OneApplication.finishAllActivities();
[参考资料]
http://stackoverflow.com/questions/22429197/controlling-android-activity-restart-after-a-process-stops
http://stackoverflow.com/questions/5423571/prevent-activity-stack-from-being-restored
https://groups.google.com/forum/#!topic/android-developers/snTPpksX9TU
- android 重启应用
- android重启应用
- Android应用重启
- android应用实现重启
- Android重启应用程序代码
- Android重启应用程序代码
- Android重启应用程序代码
- android 重启当前应用
- Android重启应用程序代码
- Android应用关闭,重启
- android 应用重启 关闭
- Android重启应用程序代码
- android 应用重启实现
- android 应用 捕获异常 重启应用
- android 重启应用(cocos2d-x重启游戏)
- Android重启应用和重启手机
- android关闭应用 service 重启问题
- android应用实现重启系统
- java按引用传递值
- shell技巧
- maven_spring_cxf
- <iOS>常用手势
- SharedPreferences 在Service中调用示例
- Android应用重启
- 国内外研究主页集合:计算机视觉-机器学习-模式识别-计算机视觉领域的一些牛人博客
- MyEclipse断点调试方法
- Hudson 乱码(console控制台输出乱码)
- WinGW安装
- 搭建dubbo测试环境
- Leetcode 297 Serialize and Deserialize Binary Tree(序列化与反序列化二叉树)
- 以调整复决定系数和AIC为模型选择标准,建立前进法、后退法、逐步回归法的r语言代码
- 解决 org.hibernate.HibernateException: Could not obtain transaction-synchronized Session for cu