Android 应用崩溃后重启的机制

一、出现的场景

  在开发过程中,想必你也一定遇到过这样的问题,当我们的应用发生Crash时异常退出,然后又自动启动跳转到未知页面,此时应用在崩溃前保存的全局变量被重置,用户状态丢失,显示数据错乱。更让我们头疼的是,这种崩溃后重启的情况,并不是每次都会遇到,那么究竟是因为什么呢?

  经测试,在 Android 的 API 21 ( Android 5.0 ) 以下,Crash 会直接退出应用,但是在 API 21 ( Android 5.0 ) 以上,系统会遵循以下原则进行重启:

  1. 包含 Service,如果应用 Crash 的时候,运行着Service,那么系统会重新启动 Service。
  2. 不包含 Service,只有一个 Activity,那么系统不会重新启动该 Activity。
  3. 不包含 Service,但当前堆栈中存在两个 Activity:Act1 -> Act2,如果 Act2 发生了 Crash ,那么系统会重启 Act1。
  4. 不包含 Service,但是当前堆栈中存在三个 Activity:Act1 -> Act2 -> Act3,如果 Act3 崩溃,那么系统会重启 Act2,并且 Act1 依然存在,即可以从重启的 Act2 回到 Act1。

看了上述解释,我们终于知道应用在什么种情况下才会重启。

二、解决方法

   维护所有已经打开的Activity到一个List中,崩溃时在Thread.UncaughtExceptionHandler 中finish掉所有Activity, 这样按上述列举的规则系统就不会自动重启相应的Activity了。

你可能感兴趣的:(Android)