Activity的生命周期(大概是网上最全的版本了)

生命周期:1.典型情况下的生命周期 :有用户参与的情况下(当然手机的各种状态都是理想情况下)
2.异常情况下的生命周期:指的是现实情况下,例如手机内容不足。Activity被系统回收,
还有就是当前Configuration发生变化从而导致Activity被销毁重建等。(Actvity在异常情况下,表现十分微妙。)


1.典型情况下的生命周期:如下图所示

如下代码所示:

public classMainActivityextendsAppCompatActivity {
private static finalStringTAG="bill";
@Override
protected voidonCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.d(TAG,"onCreate()");
}
@Override
protected voidonRestart() {
super.onRestart();
Log.d(TAG,"onRestart()");
}
@Override
protected voidonStart() {
super.onStart();
Log.d(TAG,"onStart()");
}
@Override
protected voidonResume() {
super.onResume();
Log.d(TAG,"onResume()");
}
@Override
protected voidonPause() {
super.onPause();
Log.d(TAG,"onPause()");
}
@Override
protected voidonStop() {
super.onStop();
Log.d(TAG,"onStop()");
}
@Override
protected voidonDestroy() {
super.onDestroy();
Log.d(TAG,"onDestroy()");
}
}

上面代码是把activity中所有的生命周期都打印了出来。
那么我们可以看到,第一次启动的时候运行顺序:

以下就不意义列举各种正常情况了:
只写结果:
1.正常情况下,oncreate() onstart() onresume()
2.如果当前activity A打开另一个activity B或点击home键进入桌面,那么此时执行activity A的onpause() onstop()方法,当然此时有一种特殊的activity B是不会调用onstop()方法,只是会调用onpause()方法,那就是,此activity B的主题是透明色的。
3.当回到activity A的时候,调用 onRestart() onstart() onresume()方法
4.当activity被系统回收以后再次打开,生命周期的调用顺序和1是一样的,但是仅仅是生命周期的调用顺序,并不代表其他过程也一样。
5.生命周期配对:oncreate() ondestroy()
onstar() onstop()
onresume() onpause()

那么问题来了:
activity A打开activity B的时候,activity A的onpause()和activity的onResume()方法执行的先后顺序是怎样的?
打印日志可以看出,两个activity调用的生命周期方法,竟然载同一个线程内,如图

从上图可以看出,activity A的onpause()方法先执行,然后执行依次activity B的onCreate() onstart() onResume()方法,再去执行A的onstop()等方法。
另一方面,Android官方也说过,不能在onpause中做一些重量级操作,毕竟要当前的activity先执行完onpause()才能再执行下一个activity的开始生命周期。
2.异常情况下的生命周期
1)资源相关的activity发生改变,导致activity被杀死并重建
例子:资源相关的配置发生改变、系统内存不足的时候,activity可能会被杀死。
在activity下添加以下方法:

@Override
public voidonSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putString(OUTSTATE,"我被保存下来了");
Log.d(TAG,"Thread :"+ Thread.currentThread() +",onSaveInstanceState()");
}

@Override
public voidonRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
if(savedInstanceState !=null) {
String outstate = savedInstanceState.getString(OUTSTATE);
Log.d(TAG,"onRestoreInstanceState() outstates = "+ outstate);
}
Log.d(TAG,"Thread :"+ Thread.currentThread() +",onRestoreInstanceState()");
}

分析:资源相关配置发生改变:
从竖屏转换成横屏的时候,日志如下:

从横屏转换成竖屏的时候,日志如下:

此时知道,我们的activity如果屏幕旋转,会造成生命周期的改变,一般来说是这样:
onpause() -> onsaveinstancestate() -> onstop() -> ondestroy() -> oncreate() -> onstart() -> onrestoreinstancestate() ->onresume()

而且onrestoreinstancestate()能获取到onsaveinstancestate()保存下来的数据,并且调用顺序是在onstart()方法之后。
但是,有一点,日志里边没有说明的:onsaveinstancestate()方法的调用时机是在onstop()之前,而且又和onpause()没有时间顺序上的关系。(待验证)
值得说明的一个是:在执行完activity的onsaveinstancestate()方法之后,还会activity会委托window保存数据,接着window委托他的顶级容器去保存数据,顶层容器是一个viewgroup,然后顶层容器会再去通知他的子元素,例如TextView去调用它的onsaveinstancestate()方法去保存它的数据。这是一个典型的委托思想,在view的绘制过程和分发机制中也是用的类似的思想。

当系统资源内存不足的时候,会由优先级从低到高依次kill activity。
这里的优先级划分:前台展示的activity最高,可见但非前台的activity中级,后台activity优先级最低。(这时候可以根据生命周期是否调用onpause onstop方法判断优先级,例如最高级是没有执行两个方法,中级是之执行了onpause方法,最低级是执行了两个方法)
刚才说的第一种情况,当屏幕的横竖屏改变的时候,activity会重新绘制,会把生命周期先结束再重新开始,那么如果我不想重新绘制activity的话,应该怎么做呢?
答:在manifest给需要设置的activity添加:android:configChanges="orientation",
当然在sdk>13的时候还要加上一个属性scrrenSize,变成:android:configChanges="screenSize|orientation",设置了当前的属性,顾名思义:这个是配置改变的时候,屏幕的横竖配置改变的时候。

并且加上下面的代码:

    @Override
    public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
    switch(newConfig.orientation){
    case Configuration.ORIENTATION_LANDSCAPE:
    Log.d(TAG,"变成了横着的");
    break;
    case Configuration.ORIENTATION_PORTRAIT:
    Log.d(TAG,"变成了竖着的");
    break;
    }
    }

当屏幕的横竖改变的时候,打印日志为:

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

推荐阅读更多精彩内容