Activity异常情况下的生命周期

Activity异常情况下的生命周期

情况1:资源相关的系统配置发生改变导致Activity被杀死并重新创建
当程序启动时,系统就会根据当前设备的情况去加载合适的Resource资源,比如说横屏手机和竖屏手机会拿到两张不同的图片(设定了landscape或者portrait状态下的图片)。比如说当前Activity处于竖屏状态,如果突然旋转屏幕,由于系统配置发生了改变,在默认情况下,Activity就会被销毁并且重新创建,当然我们也可以组织系统重新创建我们的Activity。

在默认情况下,如果我们的Activity不做特殊处理,那么当系统配置发生改变后,Activity就会被销毁并重新创建

这里写图片描述

   当系统配置发生改变后,Activity会被销毁,其onPause、onStop、onDestory均会被调用,同时由于Activity是在异常情况下终止的,系统会调用onSaveInstanceState来保存当前Activity的状态。这个方法的调用时机是在onStop之前,它和onPause没有既定的时序关系,它既可能在onPause之前调用,也可能在onPause之后调用,需要强调的一点是,这个方法只会出现在Activity被异常终止的情况下,正常情况下系统不会回调这个方法,当Activity被重新创建后,系统会调用onRestoreInstanceState,并且把Activity销毁时onSaveInstanceState方法所保存的Bundle对象作为参数同时传递给onRestoreInstanceState和onCreate方法来判断Activity是否被重建了,如果被重新建了,那么我们就可以取出之前保存的数据并恢复,从时序来说,onRestoreInstanceState的调用时机在onStart之后。

   同时,我们知道,在onSaveInstanceState和onRestoreInstanceState方法中,系统自动为我们做了一定的恢复工作,当Activity在异常情况下需要重新创建时,系统会默认为我们保存当前Activity的视图结构,并且在Activity重启后为我们恢复这些数据,比如文本框中用户输入的数据,ListView滚动的位置等。这些View相关的状态系统都能够默认为我们恢复。具体针对某一个特定的View系统能为我们恢复哪些数据,我们可以查看View的源码,和Activity一样,每个View都有onSaveInstanceState和onRestoreInstanceState这两个方法

   接收的位置可以选择onRestoreInstanceState或者onCreate,二者的区别时:onRestoreInstanceState一旦被调用,其参数Bundle savedInstanceState 一定是有值的,我们不用额外的判断是否为空,但是onCreate不行,onCreate如果是正常启动的话,其参数Bundle savedInstanceState为null,所以必须额外判断,这两个方法任意一个都可以进行数据恢复,官方文档建议采用onRestoreInstanceState去恢复数据。

情况2:资源内存不足导致低优先级的Activity被杀死

(1)前台Activity,正在和用户交互的Activity,优先级最高
(2)可见但非前台Activity,比如Activity中弹了个对话框,导致Activity可见但是位于后台无法和用户直接交互。
(3)后台Activity,已经被暂停的Activity,比如执行了onStop,优先级最低。
当系统内存不足时,系统就会按照上述优先级去杀死目标Activity所在的进程,并在后续通过onSaveInstanceState和onRestoreInstanceState来存储和恢复数据,如果一个进程中没有四大组件在执行,那么这个进程将很快被系统杀死,因此一些后台工作不适合脱离四大组件而独自运行在后台中,这样进程很容易被杀死,比较好的方法是将后台工作放入Service中从而保证进程有一定的优先级,这样就不会轻易地被系统杀死。

上面分析了系统地数据存储和恢复机制,我们知道,当系统配置发生改变后,Activity会被重新创建,那么有没有办法不重新创建呢,答案是有的,接下来我们就分析这个问题,系统配置发生改变后,Activity会被重新创建,那么有没有办法不重新创建呢?
系统配置中有很多内容,如果当某项内容发生改变后,我们不想系统重新创建Activity可以给configChanges熟悉。比如不想让Activity在屏幕旋转地时候重新创建,就可以给configChanges属性添加orientation这个值:
android:configChanges=”orientation”

如果我们想指定多个值,可以用“|”连接起来,比如android:configChanges=”orientation|keyboardHidden”。系统配置中所含地项目是非常多的,下面介绍每个项目的含义。

这里写图片描述
                              表1-1 configChanges的项目和含义

从表1-1可以知道,如果我们没有在Activity的configChanges属性中指定该选项的话,当配置发生改变后就会导致Activity重新创建。上面表格中的项目很多,但是我们常用的只有locale、orientation和keyboardHidden这三个选项。其他很少使用,选哟注意的是screenSize和smallestScreenSize,他们两个比较特殊,他们的行为和编译选项有关,但和运行环境无关

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值