Activity启动模式

562 阅读5分钟

前言

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,
    那么当闹铃响了的时候,按返回键应该进入闹铃设置界面。