详谈Activity生命周期

activity生命周期

一、Activity的生命周期如上图所示,一目了然:

1、onCreate:表示Activity正在被创建,在这里可以做一些初始化的操作,比如调用setContentView去加载界面布局资源、初始化Activity所需数据等。

2、onStart:表示Activity正在被启动,即将开始,此时Activity已经可见,但是还没有出现在前台,无法和用户进行交互操作。

3、onResume:此时Activity已经出现在前台可见,并且开始活动,可以和用户进行操作。

4、onPause:表示Activity正在停止,在这里不能做一些太耗时的操作,因为从当前Activity去打开新的Activity时,先执行当前Activity的onPause方法后才去创建新的Activity(onCreate -> onStart -> onResume),所以如果做了耗时的操作会影响新Activity的显示。

5、onStop:表示Activity即将停止,从前台进入后台。

6、onDestroy:Acitvity即将被销毁,在此可以做一些回收工作和释放资源。

7、onRestart:表示Acitvity正在重新启动。当Activity从前台进入后台(onPause -> onStop)后又从后台进入前台时调用此方法。比如用户按下Home键或者打开新的Activity后又回到这个Activity。

二、Activity各生命周期方法的执行情况:

1、第一次启动Activity:onCreat -> onStart -> onResume;

2、用户打开新的Activity或切换到桌面:onPause -> onStop;

注:如果新打开的Activity采用透明主题(之前的Activity还能看到),当前Activity不会回调onStop;

3、用户在此回到当前Activity时:onRestart -> onStart -> onResume;

4、用户按下back键回退或调用finish时:onPause -> onStop -> onDestroy;

5、从整个生命周期来说,onCreat和onDestroy是配对的,分表标识着Activity的创建和销毁,并且只有一次调用。从Activity是否可见来说,onStart和onStop是配对的,随着用户的操作或者设备屏幕的点亮和熄灭,着两个方法可能被调用多次。从Activity是否在前台来说,onResume和onPause是配对的,随着用户操作或者设备屏幕的点亮和熄灭,这两个方法可能被多次调用。

6、假设当前Activity为A,此时用户打开新的Activity B,他们的生命周期方法调用是怎样的?

A  onPause -> B onCreat -> B onStart -> B onResume -> A onStop

三、onSaveInstanceState 和 onRestoreInstanceState

上面讲到的是正常情况下典型的Activity的生命周期,下面我们来看一下异常情况下的生命周期:

1、资源相关的系统配置发生改变导致Activity被杀死并重新创建:

1)

比较常见的情况比如旋转手机屏幕为了适配而加载不同分辨率的图片,键盘的显示与隐藏,系统语言的改变,系统会重新配置相关资源导致Activity被杀死并重新创建。

当系统配置发生变化后Activity会被销毁(onPause -> onStop -> onDestroy),同时由于Activity是在异常情况下终止的,系统会调用onSaveInstanceState来保存Activity当前状态。这个方法的调用是在onStop之前,他和onPause没有既定的时序关系,既可能在onPause之前也可能在onPause之后(这个方法只会出现在Activity异常终止的情况下,正常情况下系统不会回调这个方法)。当Activity被重新创建后,系统会调用onRestoreInstanceState,并且把Activity销毁时onSaveInstanceState方法所保存的Bundle对象作为参数传递给onRestoreInstanceStae和onCreat,因此我们可以通过onRestoreInstanceState和onCreat方法来判断Activity是否被重新创建了,如果被重建了,那么我们可以取出之前保存的数据并恢复。从时序上来说,onRestoreInstanceState的调用时机在onStart之后。

在onSaveInstanceState和onRestoreInstanceState方法中系统会自动做一些恢复的工作。当Activity在异常情况下需要重新创建时,系统会默认为我们保存当前Activity的视图结构,并且在Activity重启后为我们恢复这些数据,比如文本框中输入的数据、listView滚动的位置等,,这些View相关的状态系统都能够默认为我们恢复。

下面的例子来验证我们自己做数据恢复和存储情况:

在onSaveInstanceState中存储一个字符串,然后当Activity被销毁再重新创后我们再去获取之前存储的字符串。接收的位置可以选择onRestoreInstanceState或者onCreat,二者的区别是:onRestoreInstanceState一旦被调用,其参数Bundle savedInstanceState一定是有值的,我们不用额外判断是否为空;但是onCreat如果是正常启动的话,其参数Bundle savedInstanceState为null,所以必须要额外判断。这两个方法我们任选一个都可以进行数据恢复,但是官方文档建议采用onRestoreInstanceState去恢复数据。下面是运行时候的数据:

注意:针对onSaveInstanceState方法有一点需要说明,系统只会在Activity即将被销毁并且有机会重新显示的情况下才会去调用他(系统只会在Activity异常终止的时候才会去调用onSaveInstanceState和onRestoreInstanceState来存储和恢复数据,其他情况不会触发这个过程)。

2)

我们知道,当系统配置发生改变后,Activity会被重新创建,那有没有办法不重新创建呢?答案是有的。系统配置中有很多内容,如果某项内容发生改变后我们不想让Activity重新创建,可以给Activity指定configChanges属性。比如不想让Activity在屏幕旋转的时候重新创建,就可以给configChanges属性添加 orientation这个值:

如果想指定多个值,可以用“|”连接起来,比如 android:configChanges="orientantion|keybord"。系统配置中所含的项目非常多,下面只介绍几个常用的项目:

a、orientation:屏幕方向发生了改变,这个是最常用的,比如旋转了手机屏幕;

b、keyboard:键盘类型发生了改变,比如用户使用了外插键盘;

c、keyBoardHidden:键盘的可访问性发生了改变,比如用户调出了键盘;

d、screenSize:当屏幕的尺寸信息发生了改变,当旋转设备屏幕时,屏幕尺寸会发发生改变,这个选项比较特殊,他和编译选项有关,当编译选项中的minSdkVersion和targetSdkVersion均低于13时,此选项不会导致Activity重启,否则会导致Activity重启(API 13新添加)。

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

这种情况下的数据存储和恢复过程和情况 1 完全一致。Activity的优先级从高到低可以分为三种:

a、前台Activity :正在和用户交互的Activity,优先级最高。

b、可见但非前台Activity:比如Activity中弹出了一个对话框,导致Activity可见但是位于后台无法和用户直接交互。

c、后台Activity:已经被暂停了的Activyti,比执行了onStop,优先级最低。

当系统内存不足时,系统就会按照上述优先级去杀死目标Activity所在的进程,并在后续通过onSaveInstanceState和onRestoreInstanceState来存储和恢复数据。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容