一、发生配置更改
有许多事件可以触发配置更改。比如,屏幕纵向和横向的变化、语言或输入设备的变化。
当发生配置更改时,该活动将被销毁并重新创建。原来的活动将触发 onPause()
,onStop()
和 onDestroy()
。新建的活动将触发 onCreate()
,onStart()
,onResume()
。
可以使用 ViewModels
,onSaveInstanceState()
方法和本地存储的组合方法来保存并恢复活动的 UI 状态。
1. 处理多窗口情况
当应用程序进入多窗口模式(Android 7.0(API 级别 24)及更高版本可用)时,会发生配置更改。多窗口模式下调整大小也会发生此行为。
在多窗口模式下,虽然有两个应用程序对用户可见,但只有与用户交互的应用程序位于前台并具有焦点。该活动处于恢复状态,而另一个窗口中的应用处于暂停状态。
当用户从应用程序 A 切换到应用程序 B 时,系统会调用应用程序 A 的 onPause()
方法和应用程序 B 的 onResume()
方法。
二、活动或对话框出现在前台
如果新的活动或对话框部分覆盖正在运行的活动,则被部分覆盖的活动将失去焦点并进入暂停状态。当被覆盖的活动返回到前台并重新获得焦点时,它会调用 onResume()
方法。
如果是完全覆盖正在运行的活动,则被覆盖的活动将失去焦点并进入停止状态。然后,系统迅速调用 onPause()
和 onStop()
方法。当被覆盖活动的同一实例回到前台时,系统将调用 onRestart()
,onStart()
以及 onResume()
方法。
注意:当用户点击概览或主页按钮时,当前活动相当于是被完全覆盖。
三、用户点击后退按钮
如果活动处在前台,而用户点击后退按钮,该活动将调用 onPause()
,onStop()
和 onDestroy()
回调。除了被销毁之外,该活动也从返回栈中移除。
需要注意的是,默认情况下,onSaveInstanceState()
回调在这种情况下不会触发。这是因为假设用户点击后退按钮而不期望返回到活动的同一实例。但是,你应该重写 onBackPressed()
方法来实现一些自定义行为,例如弹出 “确认 - 退出” 对话框。
如果重写 onBackPressed()
方法,最好调用 super.onBackPressed()
。否则,后退按钮的行为可能会刺激到用户。
四、系统杀死应用进程
如果系统需要为前台应用提供内存,那么处于后台的应用程序很可能会被杀死。