android:launchMode
這個屬性定義瞭應該如何啟動Activity的一個指令。有四種工作模式會跟Intent對象中的Activity標記(FLAG_ACTIVITY_*常量)結合在一起用來決定被調用Activity在處理Intent對象時應該發生的事情,這四種模式是:
standard
singleTop
singleTask
singleInstance
默認的模式是standard。
像下表顯示的那樣,這四種模式被分成兩組,standard和singleTop為一組,singleTask和singleInstance為一組。帶有standard和singleTop啟動模式的Activity能夠被實例化多次。其實例能夠屬於任何任務,並且能夠在Activity的堆棧中被定為。通常是調用startActivity()方法把它們加載到任務中(除非Intent對象包含瞭一個FLAG_ACTIVITY_NEW_TASK指令,這種情況下會選擇啟動一個新的任務。)
相比之下,singleTask和singleInstance啟動模式的Activity隻能啟動一個任務。它們始終是Activity堆棧的根節點。並且設備每次隻能擁有一個這樣的Activity—隻有一個這樣的任務。
standard和singleTop模式彼此在一個方面有所不同:對於standard啟動模式的Activity,每次要有一個新的Intent對象才能啟動,系統會創建一個新的Activity類的實例來響應Intent對象的請求。每個實例處理一個Intent對象。同樣,singleTop啟動模式的Activity也會創建一個新的實例來處理一個新的Intent對象。但是,如果目標任務中在堆棧的頂部已經有瞭這個Activity的實例,那麼這個實例會接受這個新的Intent對象(在onNewIntent()回調方法中調用);而不是創一個新的Activity實例。另一種情況,如:如果singleTop啟動模式的Activity的一個實例,在目標任務中已經存在,但是它沒有在任務堆棧的頂部,或者是在堆棧的頂部,卻不是目標任務,那麼就會創建一個新的Activity實例,並把它壓入目標任務堆棧。
singleTask和singleInstance模式彼此也在一個方面有所不同:singleTask模式的Activity,允許其他Activity作為它所在任務的一部分。它始終在所在任務的根節點,但是其他的Activity(需要是standard和singleTop模式的Activity)能夠被加載到它的任務中。而singleInstance模式的Activity,不允許其他的Activity做它所在任務的一部分。它是其任務中唯一的Activity。如果要啟動另外的Activity,那麼被啟動的Activity要關聯到不同的任務中—就像是在Intent對象中設置瞭FLAG_ACTIVITY_NEW_TASK標記一樣。
使用場景 | 啟動模式 | 支持多實例嗎? | 解釋 |
針對大多數Activity的啟動模式 | standard | Yes | 默認啟動模式,系統總是在目標任務中創建一個新的Activity實例,並把Intent對象發送給它。 |
singleTop | 有條件的 | 如果這中模式的Activity始終存在與目標任務堆棧的頂部,系統就會通過調用它的onNewIntent()方法,把Intent對象發送給這個實例,而不是創建一個的Activity實例。 | |
特殊的啟動模式,通常不推薦使用。 | singleTask | No | 系統在一個新任務堆棧的根節點處創建這個Activity,並且把Intent對象發送給它。但是,如果這個Activity的實例已經存在,系統就會通過調用它的onNewIntent()方法,把Intent對象發送給這個實例,而不是創建一個的Activity實例。 |
singleInstance | No | 除瞭系統不能把其他的Activity加載到該Activity實例所歸屬的任務中之外,其他與singleTask模式相同。這種模式的Activity始終是單獨存在的,並且是其任務中唯一的成員 |
如上表所示,standard模式是默認模式,並且適用於大多數Activity。singleTop也是一種通用的,且被很多Activity類型所使用的啟動模式。其他模式(singleTask和singleInstance)是不推薦給大多數應用程序使用的,因為它們會產生用戶不熟悉的交互模式,並且與大多數應用程序也會產生差異。
不管選擇瞭那種啟動模式,都要測試Activity在啟動期間的可用性,並且在使用Back按鈕時能夠返回到其他的Activity和任務。
摘自 FireOfStar的專欄