启动模式还是比较难以理解的,虽然我尽量用最简单的方式来陈述,但原谅在下装逼功力有限,建议还是必须对着代码敲一遍
一: Actiivity和Task
- Activity属于哪个Task,由什么来决定的?
- Activity会一直在这个task中吗?
- 如果不是又会到什么样的task中呢?
这一切都可以在Activity的taskAffinity属性中找到答案,Activity的taskAffinity属性决定了它在哪个Task中
二 :Activity的taskAffinity属性和task的taskAffinity属性值
- 每个Activity都有taskAffinity属性,这个属性指出了它希望进入的Task
- 如果一个Activity没有显示指明taskAffinity属性,那么它的taskAffinity属性就是Application指明的taskAffinity属性
- 如果Application中也没有指明的taskAffinity属性,那么该taskAffinity的值就等于包名
- Task的taskAffinity属性值等于根Activity的taskAffinity的属性值。(根Activity:该Task里最底层的Activity)
三:一般情况下创建的Activity都会在创建它的Task中,并且大部分都在这里度过了它的整个生命。然而有一些情况,创建的Activity会被分配其它的Task中去,有的甚至,本来在一个Task中,之后出现了转移--我们叫他重新宿主。有两种情况
- 如果该Activity的allowTaskReparenting设置为true,它进入后台,当一个和它有相同affinity的Task进入前台时,它会重新宿主,进入到该前台的task中。看个小栗子,验证下是否正确
- 这里我们新建两个Application ApplicationFirst 和ApplicationSecond 并给两个Appliction设置相同的taskAffinity属性值,但是ApplicationFirst设置 allowTaskReparenting设置为true。
- 现在我们先点开ApplicationFirst,然后home键,在点开ApplicationSecond,我们看到的界面确实ApplicationFirst的界面,为什么呢?本来应该是显示ActivitySecond,但是我们却看到了ActivityFirst。实际上ActivitySecond也被加载了,只是ActivityFirst重新宿主,所以看到了ActivityFirst。
- 如果加载某个Activity的intent,Flag被设置成FLAG_ACTIVITY_NEW_TASK时,它会首先检查是否存在与自己taskAffinity相同的Task,如果存在,那么它会直接宿主到该Task中,如果不存在则重新创建Task。
新建一个ApplicationTwo,taskAffinity属性设置为: android:taskAffinity="com.zyg.test"
AndroidManifest文件
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.zhang.testing.applicationtwo">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity"
android:taskAffinity="com.zyg.test"
>
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
在建立个ApplicationOne ,一个MainAcitivity 一个NewTaskFlag 的Activity,我们用MainActivity启动NewTaskFlag ,并设置
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView view= (TextView) findViewById(R.id.btn_newTaskflag);
view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainActivity.this, NewTaskFlag.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intent);
}
});
}
}
ApplicationOne 的AndroidManifest文件。NewTaskFlag 给这个Activity设置 android:taskAffinity="com.zyg.test",和ApplicationTwo的taskAffinity 值一样。
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.zhang.testing.applicationone">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name=".MainActivity"
>
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity
android:name=".NewTaskFlag"
android:taskAffinity="com.zyg.test"
>
</activity>
</application>
</manifest>
然后我们先启动ApplicationTwo,然后Home键,在启动ApplicationOne,然后主界面跳转到NewTaskFlag activity界面。然后我们开始回退键。发现了什么吗?看到退出的顺序了吗? NewTaskFlag 然后avtivitySecond (ApplicationTwo对应的Activity) 然后MainActivity 。那么说明了什么?当启动NewTaskFlag ,会先检查有没有和自己taskAffinity相同的Task,如果存在,那么它会直接宿主到该Task中,如果不存在则重新创建Task。
如有错误,欢迎指正,谢谢,如转载请在文章中明显注明出处