Android應用程序組件Activity的"singleTask"(1)
在Android應用程序中,可以配置Activity以四種方式來啟動,其中最令人迷惑的就是"singleTask"這種方式了,官方文檔稱以這種方式啟動的Activity總是屬于一個任務的根Activity。果真如此嗎?本文將為你解開Activity的"singleTask"之謎。
在解開這個謎之前,我們先來簡單了解一下在Android應用程序中,任務(Task)是個什么樣的概念。我們知道,Activity是 Android應用程序的基礎組件之一,在應用程序運行時,每一個Activity代表一個用戶操作。用戶為了完成某個功能而執行的一系列操作就形成了一 個Activity序列,這個序列在Android應用程序中就稱之為任務,它是從用戶體驗的角度出發,把一組相關的Activity組織在一起而抽象出 來的概念。
對初學者來說,在開發Android應用程序時,對任務的概念可能不是那么的直觀,一般我們只關注如何實現應用程序中的每一個Activity。事實 上,Android系統中的任務更多的是體現是應用程序運行的時候,因此,它相對于Activity來說是動態存在的,這就是為什么我們在開發時對任務這 個概念不是那么直觀的原因。不過,我們在開發Android應用程序時,還是可以配置Activity的任務屬性的,即告訴系統,它是要在新的任務中啟動 呢,還是在已有的任務中啟動,亦或是其它的Activity能不能與它共享同一個任務,具體配置請參考官方文檔:
http://developer.android.com/gui ... and-back-stack.html
它是這樣介紹以"singleTask"方式啟動的Activity的:
The system creates a new task and instantiates the activity at the root of the new task. However, if an instance of the activity already exists in a separate task, the system routes the intent to the existing instance through a call to its onNewIntent() method, rather than creating a new instance. Only one instance of the activity can exist at a time.
它明確說明,以"singleTask"方式啟動的Activity,全局只有***個實例存在,因此,當我們***次啟動這個Activity時,系統 便會創建一個新的任務,并且初始化一個這樣的Activity的實例,放在新任務的底部,如果下次再啟動這個Activity時,系統發現已經存在這樣的 Activity實例,就會調用這個Activity實例的onNewIntent成員函數,從而把它激活起來。從這句話就可以推斷出, 以"singleTask"方式啟動的Activity總是屬于一個任務的根Activity。
但是文檔接著舉例子說明,當用戶按下鍵盤上的Back鍵時,如果此時在前臺中運行的任務堆棧頂端是一個"singleTask"的Activity,系統會回到當前任務的下一個Activity中去,而不是回到前一個Activity中去,如下圖所示:
真是坑爹啊!有木有!前面剛說"singleTask"會在新的任務中運行,并且位于任務堆棧的底部,這里在Task B中,一個赤裸裸的帶著"singleTask"標簽的箭頭無情地指向Task B堆棧頂端的Activity Y,剛轉身就翻臉不認人了呢!
獅屎勝于熊便,我們來做一個實驗吧,看看到底在啟動這個"singleTask"的Activity的時候,它是位于新任務堆棧的底部呢,還是在已有任務的頂部。