Intent.FLAG_ACTIVITY_NEW_TASK 理解
首先要强调下,下边两个LaunchMode启动模式功能,已作区分:
-
当一个Activity被设置为singletask时
(1)它并没有创建新的任务栈(TaskId都是一样的)
(2)如果它已经存在于栈中,再次请求触发此Activity时,会调用此类实例的onNewIntent方法,不会重新创建新的实例
(3)如果此类所在的任务栈上面有其它Activity,那么其之上的Activity会全部出栈。 -
当一个Activity被设置为singleinstance时
(1)如果此Activity没有实例,它会创建一个新的任务栈。(两个TaskId不一样)
(2)如果任务栈中已经有此实例,会调用onNewIntent方法,不会创建新的任务栈和实例
(3)独立成Taskstack ,并且有且仅有你自己 。而且始终保持一个实例离栈的时候 , 先退当前的task ,再退另外的task
FLAG_ACTIVITY_NEW_TASK 比较标准解释如下:
首先会查找是否存在和被启动的Activity具有相同的亲和性的任务栈(即taskAffinity,注意同一个应用程序中的activity的亲和性相同),如果有,则直接把这个栈整体移动到前台,并保持栈中旧activity的顺序不变,然后被启动的Activity会被压入栈,如果没有,则新建一个栈来存放被启动的activity,注意,默认情况下同一个应用中的所有Activity拥有相同的关系(taskAffinity).
个人理解:
默认情况下同一个应用中的所有Activity,都拥有相同的关系(taskAffinity),即由FLAG_ACTIVITY_NEW_TASK开启的新Activity,也都在同一个任务栈中(与Application相同的任务栈),若想使新Activity进入不同栈中,则还需要如下配置:
<activity
android:name=".ui.activity.OtherTaskActivityXXX"
android:taskAffinity="android.task.browser"/> //注意这里的 taskAffinity
并且在该OtherTaskActivityXXX页面中,若再开启的其他页面,那么所有的其他页面,都将被压入到这个新的任务栈中。
查看任务栈Id:
int TaskId = mActivity.getTaskId();