Activity啓動方式有四種,分別是:
standard
singleTop
singleTask
singleInstance
能夠根據實際的需求爲Activity設置對應的啓動模式,從而能夠避免建立大量重複的Activity等問題。
設置Activity的啓動模式,只須要在AndroidManifest.xml裏對應的<activity>標籤設置android:launchMode屬性,例如:html
下面是這四種模式的做用:
standard
默認模式,能夠不用寫配置。在這個模式下,都會默認建立一個新的實例。所以,在這種模式下,能夠有多個相同的實例,也容許多個相同Activity疊加。
例如:
若我有一個Activity名爲A1, 上面有一個按鈕可跳轉到A1。那麼若是我點擊按鈕,便會新啓一個Activity A1疊在剛纔的A1之上,再點擊,又會再新啓一個在它之上……
點back鍵會依照棧順序依次退出。
singleTop
能夠有多個實例,可是不容許多個相同Activity疊加。即,若是Activity在棧頂的時候,啓動相同的Activity,不會建立新的實例,而會調用其onNewIntent方法。
例如:
若我有兩個Activity名爲B1,B2,兩個Activity內容功能徹底相同,都有兩個按鈕能夠跳到B1或者B2,惟一不一樣的是B1爲standard,B2爲singleTop。
若我意圖打開的順序爲B1->B2->B2,則實際打開的順序爲B1->B2(後一次意圖打開B2,實際只調用了前一個的onNewIntent方法)
若我意圖打開的順序爲B1->B2->B1->B2,則實際打開的順序與意圖的一致,爲B1->B2->B1->B2。
singleTask
只有一個實例。在同一個應用程序中啓動他的時候,若Activity不存在,則會在當前task建立一個新的實例,若存在,則會把task中在其之上的其它Activity destory掉並調用它的onNewIntent方法。
若是是在別的應用程序中啓動它,則會新建一個task,並在該task中啓動這個Activity,singleTask容許別的Activity與其在一個task中共存,也就是說,若是我在這個singleTask的實例中再打開新的Activity,這個新的Activity仍是會在singleTask的實例的task中。
例如:
若個人應用程序中有三個Activity,C1,C2,C3,三個Activity可互相啓動,其中C2爲singleTask模式,那麼,不管我在這個程序中如何點擊啓動,如:C1->C2->C3->C2->C3->C1-C2,C1,C3可能存在多個實例,可是C2只會存在一個,而且這三個Activity都在同一個task裏面。
可是C1->C2->C3->C2->C3->C1-C2,這樣的操做過程實際應該是以下這樣的,由於singleTask會把task中在其之上的其它Activity destory掉。
操做:C1->C2 C1->C2->C3 C1->C2->C3->C2 C1->C2->C3->C2->C3->C1 C1->C2->C3->C2->C3->C1-C2
實際:C1->C2 C1->C2->C3 C1->C2 C1->C2->C3->C1 C1->C2
如果別的應用程序打開C2,則會新啓一個task。
如別的應用Other中有一個activity,taskId爲200,從它打開C2,則C2的taskIdI不會爲200,例如C2的taskId爲201,那麼再從C2打開C一、C3,則C二、C3的taskId仍爲201。
注意:若是此時你點擊home,而後再打開Other,發現這時顯示的確定會是Other應用中的內容,而不會是咱們應用中的C1 C2 C3中的其中一個。
singleInstance
只有一個實例,而且這個實例獨立運行在一個task中,這個task只有這個實例,不容許有別的Activity存在。
例如:
程序有三個ActivityD1,D2,D3,三個Activity可互相啓動,其中D2爲singleInstance模式。那麼程序從D1開始運行,假設D1的taskId爲200,那麼從D1啓動D2時,D2會新啓動一個task,即D2與D1不在一個task中運行。假設D2的taskId爲201,再從D2啓動D3時,D3的taskId爲200,也就是說它被壓到了D1啓動的任務棧中。
如果在別的應用程序打開D2,假設Other的taskId爲200,打開D2,D2會新建一個task運行,假設它的taskId爲201,那麼若是這時再從D2啓動D1或者D3,則又會再建立一個task,所以,若操做步驟爲other->D2->D1,這過程就涉及到了3個task了。android