- 每个Activity都有taskAffinity属性,这个属性指出了它希望进入的Task。如果一个Activity没有显式的指明该Activity的taskAffinity,那么它的这个属性就等于Application指明的taskAffinity,如果Application也没有指明,那么该taskAffinity的值就等于包名。而Task也有自己的affinity属性,它的值等于它的根Activity的taskAffinity的值。
- taskAffinity确定两件事 - Activity 更改到的父项任务(请参阅 allowTaskReparenting
属性)和通过 FLAG_ACTIVITY_NEW_TASK标志启动 Activity 时将用来容纳它的任务。
第一种情况:
如果该Activity的allowTaskReparenting设置为true,它进入后台,当一个和它有相同affinity的Task进入前台时,它会重新宿主,进入到该前台的task中。
验证:
创建两个工程application1和application2
application1包含Activity1,application2包含Activity2,它们的taskAffinity相同,Activity1的allowTaskReparenting为true。
<activity
android:name=".Activity1"
android:allowTaskReparenting="true"
android:taskAffinity="com.meituan.gaojin">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".Activity2"
android:taskAffinity="com.meituan.gaojin">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
我们启动application1,加载Activity1,然后按Home键,使该task(假设为task1)进入后台。然后启动application2,默认应该加载Activity2,但是却加载出Activity1实际上Activity2也被加载了,只是Activity重新宿主,所以看到了Activity1
第二种情况:
如果加载某个Activity的intent,Flag被设置成FLAG_ACTIVITY_NEW_TASK时,它会首先检查是否存在与自己taskAffinity相同的Task,如果存在,那么它会直接宿主到该Task中,如果不存在则重新创建Task。
launchMode和taskAffinity的结合使用:
singleTask加载模式与taskAffinity的结合
当一个应用程序加载一个singleTask模式的Activity时,首先该Activity会检查是否存在与它的taskAffinity相同的Task。
- 如果存在,那么检查是否实例化,如果已经实例化,那么销毁在该Activity以上的Activity并调用onNewIntent。如果没有实例化,那么该Activity实例化并入栈。
- 如果不存在,那么就重新创建Task,并入栈。
singleInstance加载模式与taskAffinity的结合
- 当一个应用程序加载一个singleInstance模式的Activity时,如果该Activity没有被实例化,那么就重新创建一个Task,并入栈,如果已经被实例化,那么就调用该Activity的onNewIntent;
- singleInstance的Activity所在的Task不允许存在其他Activity,任何从该Activity加载的其它Activity(假设为Activity2)都会被放入其它的Task中,如果存在与Activity2相同affinity的Task,则在该Task内创建Activity2。如果不存在,则重新生成新的Task并入栈。