Activity的四种启动模式下的生命周期(全)2019.6.11

2019.6.11下午~2019.6.12上午

四种启动模式调试

standard(默认)

在这里插入图片描述

1
2019-06-12 11:35:35.425 17012-17012/com.hikvision.myapplication D/MainActivity: onCreate:
D/MainActivity: com.hikvision.myapplication.MainActivity@8154688
2019-06-12 11:35:35.533 17012-17012/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-12 11:35:35.543 17012-17012/com.hikvision.myapplication D/MainActivity: onResume: 

1、应用刚启动,在启动页

2
2019-06-12 11:37:24.680 17012-17012/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-12 11:37:24.691 17012-17012/com.hikvision.myapplication D/MainActivity: onCreate:
D/MainActivity: com.hikvision.myapplication.MainActivity@8930151
2019-06-12 11:37:24.711 17012-17012/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-12 11:37:24.711 17012-17012/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-12 11:37:25.288 17012-17012/com.hikvision.myapplication D/MainActivity: onStop: 

2、Button启动MainActivity,新建了一个MainActivity实例

3
2019-06-12 11:38:55.801 17012-17012/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-12 11:38:55.816 17012-17012/com.hikvision.myapplication D/MainActivity: onCreate:
D/MainActivity: com.hikvision.myapplication.MainActivity@cd704b4
2019-06-12 11:38:55.834 17012-17012/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-12 11:38:55.835 17012-17012/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-12 11:38:56.426 17012-17012/com.hikvision.myapplication D/MainActivity: onStop: 

3、再按一次Button启动MainActivity,又新建了一个MainActivity实例

4*2
2019-06-12 11:39:43.024 17012-17012/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-12 11:39:43.030 17012-17012/com.hikvision.myapplication D/MainActivity: onRestart: 
2019-06-12 11:39:43.031 17012-17012/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-12 11:39:43.032 17012-17012/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-12 11:39:43.552 17012-17012/com.hikvision.myapplication D/MainActivity: onStop: 
2019-06-12 11:39:43.553 17012-17012/com.hikvision.myapplication D/MainActivity: onDestroy: 

4、按两back键返回,销毁第三个、第二个MainActivity,当前界面是第一个MainActivity。

5
2019-06-12 11:41:21.816 17012-17012/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-12 11:41:22.916 17012-17012/com.hikvision.myapplication D/MainActivity: onStop: 
2019-06-12 11:41:22.916 17012-17012/com.hikvision.myapplication D/MainActivity: onDestroy: 

5、再按一次back键退出程序

singleTop(MainActivity)

在AndroidManifest.xml文件中配置

<activity android:name=".MainActivity"
            android:launchMode="singleTop"
            android:label="this is MainActivity">

或在intent.addFlags(int flag)中指定

代码

在MainActivity中

打印当前活动的实例

Log.d("MainActivity", this.toString());

一个Button跳转到NormalActivity

case R.id.normal :
                Intent intent = new Intent(MainActivity.this, NormalActivity.class);
                startActivity(intent);
                break;

一个按钮跳转到MainActivity

case R.id.main :
                Intent intent2 = new Intent(MainActivity.this, MainActivity.class);
                startActivity(intent2);
                break;
在NormalActivity中

同样打印当前活动的实例

Log.d("NormalActivity", this.toString());

有个Button跳转到MainActivity

运行结果

1
2019-06-11 18:49:31.820 13212-13212/? D/MainActivity: onCreate:
D/MainActivity: com.hikvision.myapplication.MainActivity@8154688
2019-06-11 18:49:31.890 13212-13212/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-11 18:49:31.891 13212-13212/com.hikvision.myapplication D/MainActivity: onResume:	

1、应用刚启动,在启动页

2		
2019-06-11 15:41:41.666 9598-9598/com.hikvision.myapplication D/MainActivity: onPause:  
2019-06-11 18:49:42.503 13212-13212/com.hikvision.myapplication D/MainActivity: onNewIntent:
2019-06-11 15:41:41.667 9598-9598/com.hikvision.myapplication D/MainActivity: onResume: 

2、点击按钮跳转到MainActivity——没有创建新的实例:因为MainActivity已经在返回栈的栈顶
会onPause和onResume
在这里插入图片描述

3
D/NormalActivity: com.hikvision.myapplication.NormalActivity@6a46db6	
//NormalActivity创建并可见后,MainActivity才停止
2019-06-11 16:00:56.184 9598-9598/com.hikvision.myapplication D/NormalActivity: onCreate:
2019-06-11 16:00:56.202 9598-9598/com.hikvision.myapplication D/NormalActivity: onStart: 
2019-06-11 16:00:56.202 9598-9598/com.hikvision.myapplication D/NormalActivity: onResume: 
2019-06-11 16:00:56.823 9598-9598/com.hikvision.myapplication D/MainActivity: onStop: 

3、点击按钮跳转到NormalActivity

4 
D/MainActivity: com.hikvision.myapplication.MainActivity@9e77c31	
2019-06-11 16:03:48.037 9598-9598/com.hikvision.myapplication D/NormalActivity: onPause: 
2019-06-11 16:03:48.052 9598-9598/com.hikvision.myapplication D/MainActivity: onCreate:
2019-06-11 16:03:48.074 9598-9598/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-11 16:03:48.075 9598-9598/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-11 16:03:48.583 9598-9598/com.hikvision.myapplication D/NormalActivity: onStop: 

4、点击按钮跳转到MainActivity
此时栈顶活动是NormalActivity,因此创建一个新的MainActivity实例。
在这里插入图片描述

5
2019-06-11 16:09:18.125 9598-9598/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-11 16:09:18.130 9598-9598/com.hikvision.myapplication D/NormalActivity: onRestart: 
2019-06-11 16:09:18.131 9598-9598/com.hikvision.myapplication D/NormalActivity: onStart: 
2019-06-11 16:09:18.131 9598-9598/com.hikvision.myapplication D/NormalActivity: onResume: 
2019-06-11 16:09:18.688 9598-9598/com.hikvision.myapplication D/MainActivity: onStop: 
2019-06-11 16:09:18.689 9598-9598/com.hikvision.myapplication D/MainActivity: onDestroy: 

现在按back键返回NormalActivity,第二个MainActivity实例销毁

6
2019-06-11 16:10:56.258 9598-9598/com.hikvision.myapplication D/NormalActivity: onPause: 
2019-06-11 16:10:56.261 9598-9598/com.hikvision.myapplication D/MainActivity: onRestart: 
2019-06-11 16:10:56.262 9598-9598/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-11 16:10:56.262 9598-9598/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-11 16:10:56.789 9598-9598/com.hikvision.myapplication D/NormalActivity: onStop: 
2019-06-11 16:10:56.790 9598-9598/com.hikvision.myapplication D/NormalActivity: onDestroy: 

再按下back键返回MainActivity,NormalActivity实例销毁

7
2019-06-11 16:12:13.690 9598-9598/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-11 16:12:14.510 9598-9598/com.hikvision.myapplication D/MainActivity: onStop: 
2019-06-11 16:12:14.513 9598-9598/com.hikvision.myapplication D/MainActivity: onDestroy: 

再按一次才会退出程序,MainActivity销毁。

singleTask 栈唯一(MainActivity)

每次启动活动时系统首先在返回栈中检查是否存在该活动的实例,如果发现,则直接使用该实例,并把在这个活动上的所有活动通通出栈,如果没有发现,创建一个新的活动实例。
在这里插入图片描述

1
2019-06-11 17:04:36.306 10901-10901/? D/MainActivity: onCreate:
D/MainActivity: com.hikvision.myapplication.MainActivity@8154688
2019-06-11 17:04:36.383 10901-10901/? D/MainActivity: onStart: 
2019-06-11 17:04:36.384 10901-10901/? D/MainActivity: onResume: 

1、应用刚启动,在启动页

2
2019-06-11 18:37:42.048 13213-13213/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-11 18:37:42.048 13213-13213/com.hikvision.myapplication D/MainActivity: onNewIntent:
2019-06-11 18:37:42.049 13213-13213/com.hikvision.myapplication D/MainActivity: onResume: 

2、点击按钮跳转到MainActivity——没有创建新的实例:activity位于栈顶 时被再次start就会进入onNewIntent

3
2019-06-11 17:07:44.585 10901-10901/com.hikvision.myapplication D/MainActivity: onPause:
2019-06-11 17:07:44.596 10901-10901/com.hikvision.myapplication D/NormalActivity: onCreate:
D/NormalActivity: com.hikvision.myapplication.NormalActivity@329eb53
2019-06-11 17:07:44.612 10901-10901/com.hikvision.myapplication D/NormalActivity: onStart: 
2019-06-11 17:07:44.613 10901-10901/com.hikvision.myapplication D/NormalActivity: onResume: 
2019-06-11 17:07:45.253 10901-10901/com.hikvision.myapplication D/MainActivity: onStop: 

3、跳转到NormalActivity,新建实例,MainActivity不可见,调用onStop

4
2019-06-11 17:11:54.727 10901-10901/com.hikvision.myapplication D/NormalActivity: onPause: 
2019-06-11 17:11:54.744 10901-10901/com.hikvision.myapplication D/MainActivity: onRestart: 
2019-06-11 17:11:54.744 10901-10901/com.hikvision.myapplication D/MainActivity: onStart:
2019-06-11 18:36:58.007 13213-13213/com.hikvision.myapplication D/MainActivity: onNewIntent:  
2019-06-11 17:11:54.744 10901-10901/com.hikvision.myapplication D/MainActivity: onResume: 
2019-06-11 17:11:55.300 10901-10901/com.hikvision.myapplication D/NormalActivity: onStop: 
2019-06-11 17:11:55.300 10901-10901/com.hikvision.myapplication D/NormalActivity: onDestroy: 

4、在NormalActivity中启动MainActivity时,发现返回栈中已存在一个MainActivity的实例,并且在NormalActivity下面,于是NormalActivity从返回栈中出栈销毁,MainActivity重新成为了栈顶活动。按一下back键退出程序。
疑问?onNewIntent时机不对

singleInstance(NormalActivity的启动模式为singleInstance)

在这里插入图片描述

1
2019-06-11 19:52:46.652 14455-14455/com.hikvision.myapplication D/MainActivity: onCreate:
2019-06-11 19:52:46.653 14455-14455/com.hikvision.myapplication D/MainActivity: Task id is 29
2019-06-11 19:52:46.806 14455-14455/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-11 19:52:46.810 14455-14455/com.hikvision.myapplication D/MainActivity: onResume: 

1、启动页

2
2019-06-11 19:52:58.578 14455-14455/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-11 19:52:58.706 14455-14455/com.hikvision.myapplication D/NormalActivity: onCreate:
2019-06-11 19:52:58.710 14455-14455/com.hikvision.myapplication D/NormalActivity: Task id is 30
2019-06-11 19:52:58.728 14455-14455/com.hikvision.myapplication D/NormalActivity: onStart: 
2019-06-11 19:52:58.729 14455-14455/com.hikvision.myapplication D/NormalActivity: onResume: 
2019-06-11 19:52:59.302 14455-14455/com.hikvision.myapplication D/MainActivity: onStop: 

2、指定为singleInstance模式的活动会启用一个新的返回栈来管理这个活动(为了能够被其他的程序调用,共享活动实例)
NormalActivity存放在一个单独的返回栈里,这个栈中只有这一个活动

3
2019-06-11 19:53:19.129 14455-14455/com.hikvision.myapplication D/NormalActivity: onPause:
2019-06-11 19:53:19.148 14455-14455/com.hikvision.myapplication D/ThirdActivity: Task id is 29
2019-06-11 19:53:19.940 14455-14455/com.hikvision.myapplication D/NormalActivity: onStop: 

3、button跳转到ThirdActivity

4
2019-06-11 19:56:16.696 14455-14455/com.hikvision.myapplication D/MainActivity: onRestart: 
2019-06-11 19:56:16.700 14455-14455/com.hikvision.myapplication D/MainActivity: onStart: 
2019-06-11 19:56:16.701 14455-14455/com.hikvision.myapplication D/MainActivity: onResume: 

4、按back键返回,直接从ThirdActivity返回到了MainActivity:MainActivity和ThirdActivity都在29返回栈,按back键,ThirdActivity从返回栈中出栈,则MainActivity变成栈顶活动显示在界面上。

5
2019-06-11 20:00:55.990 14455-14455/com.hikvision.myapplication D/MainActivity: onPause: 
2019-06-11 20:00:56.000 14455-14455/com.hikvision.myapplication D/NormalActivity: onRestart: 
2019-06-11 20:00:56.000 14455-14455/com.hikvision.myapplication D/NormalActivity: onStart: 
2019-06-11 20:00:56.001 14455-14455/com.hikvision.myapplication D/NormalActivity: onResume: 
2019-06-11 20:00:56.748 14455-14455/com.hikvision.myapplication D/MainActivity: onStop: 
2019-06-11 20:00:56.748 14455-14455/com.hikvision.myapplication D/MainActivity: onDestroy: 

5、按back键返回,由于29返回栈已经空了,于是显示另一个返回栈30的栈顶活动,即NormalActivity。最后再按下back键,此时所有返回栈都已经空了,退出程序。

[总结]onNewIntent何时被调用

onNewIntent作用

当Activity(假设为A)的launchMode为singleTop且A的实例处于栈顶,或者launchMode为singleTask且A的实例已经在栈里(无论是栈顶还是栈中),再次启动Activity A时,便不会调用onCreate()去产生新的实例,而是调用onNewIntent()并重用返回栈里的A实例

总结

如果A在栈顶,那么方法回调的调用顺序依次为A.onPause() -> A.onNewIntent() -> A.onResume()。A的launchMode可以为singleTop或者是singleTask
如果A不在栈顶,此时它处于A.onStop()状态,当再次启动时,调用顺序依次是A.onStop() -> A.onNewIntent() -> A.onRestart() -> A.onStart() -> A.onResume()。A的launchMode只能是singleTask

作者:咸鱼壹号
来源:CSDN
原文:https://blog.csdn.net/weixin_38196407/article/details/88351030
版权声明:本文为博主原创文章,转载请附上博文链接!**


onNewIntent
第一种情况:activity launchMode为singleTask或者singleInstance
1、activityA start activityB
2、activityB start activityA
在第二步被执行后,activityA就会顺序执行 onNewIntent onRestart onStart onResume
第二种情况:activity launchMode为singleTop singleTask singleInstance
1、start activityA
2、activityA start activityA
在第二步被执行后,activityA就会顺序执行onPause onNewIntent onResume

疑问? 我实际执行出来的顺序:
在第二步被执行后,activityA就会顺序执行 onRestart onStart onNewIntent onResume

第一种情况其实是真正的activity被restart,第二种情况是activity位于栈顶时被再次start就会进入onNewIntent
其实理解的简单一点,无论什么模式,只有activity是同一个实例的情况下,intent发生了变化,就会进入onNewIntent中,这个方法的作用也是让你来对旧的intent进行保存,对新的intent进行对应的处理。
作者:OoYoO
链接:https://www.jianshu.com/p/ed381338a979
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

四种启动模式举例

standardActivity的默认加载方法,该方法会通过跳转到一个新的activity,同时将该实例压入到栈中(不管该activity是否已经存在在Task栈中,都是采用new操作)。例如: 栈中顺序是A B C D ,此时D通过Intent跳转到A,那么栈中结构就变成 A B C D A ,点击返回按钮的 显示顺序是 D C B A,依次摧毁。

singleTopsingleTop模式下,当前Activity D位于栈顶的时候,如果通过Intent跳转到它本身的Activity (即D),那么不会重新创建一个新的D实例,所以栈中的结构依旧为A B C D,如果跳转到B,那么由于B不处于栈顶,所以会新建一个B实例并压入到栈中,结构就变成了A B C D B。

singleTasksingleTask模式下,Task栈中只能有一个对应Activity的实例。例如:现在栈的结构为:A B C D。此时D通过Intent跳转到B,则栈的结构变成了:A B。其中的C和D被栈弹出销毁了,也就是说位于B之上的实例都被销毁了。

singleInstancesingleInstance模式下,会将打开的Activity压入一个新建的任务栈中。例如:Task栈1中结构为:A B C ,C通过Intent跳转到了D(D的模式为singleInstance),那么则会新建一个Task 栈2,栈1中结构依旧为A B C,栈2中结构为D,此时屏幕中显示D,之后D通过Intent跳转到D,栈2中不会压入新的D,所以2个栈中的情况没发生改变。如果D跳转到了C,那么就会根据C对应的launchMode的在栈1中进行对应的操作,C如果为standard,那么D跳转到C,栈1的结构为A B C C ,此时点击返回按钮,还是在C,栈1的结构变为A B C,而不会回到D。
--------------------- 作者:vipra
来源:CSDN
原文:https://blog.csdn.net/vipzjyno1/article/details/25463457
版权声明:本文为博主原创文章,转载请附上博文链接!

intent的Flags属性

Intent.FLAG_ACTIVITY_NEW_TASK (默认)
默认的跳转类型,它会重新创建一个新的Activity,不过与这种情况,比如说Task1中有A,B,C三个Activity,此时在C中启动D的话,如果在AndroidManifest.xml文件中给D添加了Affinity的值和Task中的不一样的话,则会在新标记的Affinity所存在的Task中压入这个Activity。如果是默认的或者指定的Affinity和Task一样的话,就和标准模式一样了启动一个新的Activity.

intent.FLAG_ACTIVITY_SINGLE_TOP
这个FLAG就相当于启动模式中的singletop,例如:原来栈中结构是A B C D,在D中启动D,栈中的情况还是A,B,C,D。

intent.FLAG_ACTIVITY_CLEAR_TOP
这个FLAG就相当于启动模式中的SingleTask,这种FLAG启动的Activity会把要启动的Activity之上的Activity全部弹出栈空间。例如:原来栈中的结构是A B C D ,从D中跳转到B,栈中的结构就变为了A B了。(这个方法可以用来关闭多个Activity,之后的一篇博文里面会提到)


作者:vipra
来源:CSDN
原文:https://blog.csdn.net/vipzjyno1/article/details/25463457
版权声明:本文为博主原创文章,转载请附上博文链接!

Activity相关属性taskAffinity

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值