前言
01 启动模式简单地说就是Activity启动时的策略,在AndroidManifest.xml中的标签的android:launchMode属性设置;
02 启动模式有4种,分别为standard、singleTop、singleTask、singleInstance;
Activity的四种启动模式
1、standard:
创建一个新的Activity
01 standard是活动默认的启动模式。
02 在standard启动模式下,每当启动一个新的活动,它就会在返回栈中入栈,并处于栈顶的位置。
03 每次启动都会创建该活动的一个新的实例。
2、singleTop:
栈顶不是该类型的Activity,创建一个新的Activity。否则,onNewIntent。
01 每次扫描栈顶,如果在任务栈顶发现了相同的实例则重用,否则新建并压入栈顶。
02 如果一个以singleTop模式启动的activity的实例已经存在于任务桟的桟顶,
那么再启动这个Activity时,不会创建新的实例,而是重用位于栈顶的那个实
例,并且会调用该实例的onNewIntent()方法将Intent对象传递到这个实例中。
03 如果以singleTop模式启动的activity的一个实例已经存在与任务桟中,
但是不在桟顶,那么它的行为和standard模式相同,也会创建多个实例。
3、singleTask:
回退栈中没有该类型的Activity,创建Activity,否则,onNewIntent+ClearTop。
01 与singleTop的区别是singleTask会扫描整个任务栈并制定策略。
02 使用时需要小心因为会将之前入栈的实例之上的实例全部移除,
需要格外小心逻辑。
03 在启动一个singleTask的Activity实例时,如果系统中已经存在这样一个实例
,就会将这个实例调度到任务栈的栈顶,并清除它当前所在任务中位于它上面
的所有的activity。
04 其实,把启动模式设置为singleTask,framework在启动该activity时只会把
它标示为可在一个新任务中启动,至于是否在一个新任务中启动,还要受其他
条件的限制。如果singleTask模式指定了不同的taskAffinity,也会启动一个
新的返回栈。
参考资料:
1、Activity四种启动模式和taskAffinity属性详解
2、解开Android应用程序组件Activity的"singleTask"之谜
4、singleInstance
01 指定为singleInstance模式的活动会启用一个新的返回栈来管理这个活动。
02 如果应用1的任务栈中创建了MainActivity实例,如果应用2也要激活
MainActivity,则不需要创建,两应用共享该Activity实例;
03 singleInstance模式下会有一个单独的返回栈来管理这个活动,
不管是哪个应用程序来访问这个活动,都共用的同一个返回栈。
解决了共享实例活动的问题。
04 这个的理解可以这么看:在微信里点击“用浏览器打开”一个朋友圈,
然后切到QQ再用浏览器开一个网页,再跑到哪里再开一个页面。
每次我们都在Activity中试图启动另一个浏览器Activity,但是
在浏览器端看来,都是调用了同一个自己。因为使用了singleInstance模式,
不同应用调用的Activity实际上是共享的。
注意:
01 设置了"singleTask"启动模式的Activity,它在启动的时候,
会先在系统中查找属性值affinity等于它的属性值taskAffinity的Task存在;
如果存在这样的Task,它就会在这个Task中启动,否则就会在新的任务栈中启
动。因此, 如果我们想要设置了"singleTask"启动模式的Activity在新的任务
中启动,就要为它设置一个独立的taskAffinity属性值。
02 如果设置了"singleTask"启动模式的Activity不是在新的任务中启动时,
它会在已有的任务中查看是否已经存在相应的Activity实例,
如果存在,就会把位于这个Activity实例上面的Activity全部结束掉,即最终
这个Activity 实例会位于任务的Stack顶端中。
03 在一个任务栈中只有一个”singleTask”启动模式的Activity存在。他的上面可
以有其他的Activity。这点与singleInstance是有区别的。
singleInstance,回退栈中,只有这一个Activity,没有其他Activity。
04 SingleTop适合接收通知启动的内容显示页面。
例如,某个新闻客户端的新闻内容页面,如果收到10个新闻推送,每次都打开
一个新闻内容页面是很烦人的。
05 singleTask适合作为程序入口点。
例如浏览器的主界面。不管从多少个应用启动浏览器,只会启动主界面一次,
其余情况都会走onNewIntent,并且会清空主界面上面的其他页面。
06 singleInstance应用场景:
闹铃的响铃界面。
你以前设置了一个闹铃:上午6点。在上午5点58分,你启动了闹铃设置界面,
并按 Home 键回桌面;在上午5点59分时,你在微信和朋友聊天;在6点时,闹
铃响了,并且弹出了一个对话框形式的 Activity(名为 AlarmAlertActivity)
提示你到6点了(这个 Activity 就是以 SingleInstance
加载模式打开的),你按返回键,回到的是微信的聊天界面,这是因为
AlarmAlertActivity 所在的 Task 的栈只有他一个元素, 因此退出之后这个
Task 的栈空了。如果是以SingleTask打开AlarmAlertActivity,
那么当闹铃响了的时候,按返回键应该进入闹铃设置界面。