Android開發之旅:組件生命週期(二)

引言

應用程序組件有一個生命週期——一開始Android實例化他們響應意圖,直到結束實例被銷燬。在這期間,他們有時候處於激活狀態,有時候處於非激活狀態;對於活動,對用戶有時候可見,有時候不可見。組件生命週期將討論活動、服務、廣播接收者的生命週期——包括在生命週期中他們可能的狀態、通知狀態改變的方法、及這些狀態的組件寄宿的進程被終結和實例被銷燬的可能性。

上篇Android開發之旅:組件生命週期(一)講解了論活動的生命週期及他們可能的狀態、通知狀態改變的方法。本篇將介紹服務和廣播接收者的生命週期:

  1. 服務生命週期
  2. 廣播接收者生命週期

1、服務生命週期

一個服務可以用在兩個方面:

  1. 它可以啓動且允許一直運行直到有人停止它,或者它自己停止。在這種模式,通過調用Context.startService()啓動服務及通過調用Context.stopService()停止服務。服務也可以通過調用Service.stopSelf()Service.stopSelfResult()停止自己。僅需要調用一次stopService()停止服務,而不管調用startService()了多少次。
  2. 通過使用相關接口可以編程地操作服務。客戶端建立與Service對象的一個連接及使用該連接調入服務。連接通過調用Context.bindService()建立,通過調用Context.unbindService()關閉。多個客戶端可以綁定到同一個服務。如果服務尚未啓動,bindService()可以選擇啓動它。

這兩種模式並不是完全分離的。你可以綁定到一個用startService()啓動的服務。例如,一個後臺音樂服務可以通過使用定義了音樂播放的Intent對象調用startService()啓動。直到後來,用戶可能想對播放器做一些控制或者獲取當前歌曲的一些信息,一個活動將調用bindService()與服務建立連接。在這種情況下,實際上直到最後一個綁定關閉stopService()並不會停止。

像活動一樣,一個服務也有生命週期方法,你可以執行監視它的狀態改變。但是比活動的生命週期方法更少,只有三個且它們是公有的(public)而不是受保護的(protected)(說明:活動的生命週期方法是protected的):

  1. void onCreate()
  2. void onStart(Intent intent)
  3. void onDestory()

通過這三個方法,你可以監視服務生命週期的兩個嵌套循環:

  1. 服務的整個生命時間(entire lifetime),從調用onCreate()到相應地調用onDestory()。像一個活動一樣,服務在onCreate()中做一些初始設置,且在中釋放所有的資源。例如,一個音樂播放服務可以在onCreate()中創建線程,然後在onDestory()中停止線程。
  2. 服務的活躍生命時間(active lifetime),從調用onStart()開始。這個方法傳遞參數是傳送給startService()的Intent對象。音樂服務將打開Intent,瞭解播放哪個音樂並且開始播放。
    沒有相應的回調方法,因爲服務停止沒有onStop()方法。

startService()onDestory()被所有服務調用,不管是通過Context.startService()啓動還是通過Context.bindService()啓動的。然而,onStart()僅被通過startService()啓動的服務調用。

如果一個服務允許別的綁定到它,有一些額外的回調方法來實現它:

  1. IBinder onBind(Intent intent)
  2. boolean onUnbind(Intent intent)
  3. void onRebind(Intent intent)

onBind()回調傳遞的參數是傳給bindService()的Intent對象,onUnbind()回調傳遞的參數是傳給unbindService()的Intent對象。如果服務允許綁定,onBind()返回客戶端與服務交互的通信通道。onUnbind()方法可以要求調用onRebind(),如果一個新的客戶端連接到服務。

下圖解釋了服務的回調方法。雖然,它分離了由startService()啓動的服務和由bindService()啓動的服務,記住任何服務,無論它怎麼啓動的,都可能允許客戶端綁定到它,因此任何服務可能接收onBind()onUnbind()調用。

Android開發之旅:組件生命週期(二)

2、廣播接收者生命週期

一個廣播接收者有一個回調方法:void onReceive(Context curContext, Intent broadcastMsg)。當一個廣播消息到達接收者是,Android調用它的onReceive()方法並傳遞給它包含消息的Intent對象。廣播接收者被認爲僅當它執行這個方法時是活躍的。當onReceive()返回後,它是不活躍的。

有一個活躍的廣播接收者的進程是受保護的,不會被殺死。但是系統可以在任何時候殺死僅有不活躍組件的進程,當佔用的內存別的進程需要時。

這帶來一個問題,當一個廣播消息的響應時費時的,因此應該在獨立的線程中做這些事,遠離用戶界面其它組件運行的主線程。如果onReceive()衍生線程然後返回,整個進程,包括新的線程,被判定爲不活躍的(除非進程中的其它應用程序組件是活躍的),將使它處於被殺的危機。解決這個問題的方法是onReceive()啓動一個服務,及時服務做這個工作,因此係統知道進程中有活躍的工作在做。

本系列的其它文章:

  1. Android 開發之旅:環境搭建及HelloWorld
  2. Android 開發之旅:HelloWorld項目的目錄結構
  3. Android 開發之旅:android架構
  4. Android 開發之旅:應用程序基礎及組件
  5. Android 開發之旅:應用程序基礎及組件(續)
  6. Android 開發之旅:活動與任務
  7. Android 開發之旅:進程與線程
  8. Android 開發之旅:組件生命週期(一)
  9. 建議您從頭再看一遍,絕對會有新的收穫!
  10. 從android架構到這篇基本內容都是意譯自Android SDK文檔。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章