天天看點

[Android問答] 如何了解Activity生命周期?[Android問答] 如何了解Activity生命周期?

Android官方文檔裡對Activity的生命周期有比較詳盡的描述,但由于資源回收機制帶來不确定性,我們的程式運作結果常常與預期的不符,而調試這類問題又十分消耗時間和精力。解決的根本辦法還是要了解透Activity的生命周期及相關内容,這篇文章着重介紹Activity生命周期本身,之後會用一兩篇文章來介紹如何處理異常的狀态變化。

下圖是官方文檔裡的Activity生命周期圖,其中彩色标出的四個框是Activity的四種狀态,當Activity的狀态改變時會觸發一個或多個onXXX()方法。

[Android問答] 如何了解Activity生命周期?[Android問答] 如何了解Activity生命周期?

當Acitivity第一次被建立時觸發,一般在這裡要做的事情包括建立視圖(setContentView())、向視圖填充必要的資料等等。

這個我比較少用到,按文檔上的介紹,如果Activity之前被stop過,那麼下一次onStart()方法之前會先觸發這個方法。

隻要Activity從不可見變成可見,就會觸發到這個方法,但被AlertDialog遮擋/顯示的情況不算在内。

當Activity來到最上層的時候,也就是開始與使用者直接互動時,觸發這個方法。例如本來Activity被一個AlertDialog遮擋,當這個AlertDialog消失時,onResume()方法就被觸發。

和onResume()的觸發條件剛好相反,如果Activity本來在最上層,當它要讓出最上層的位置時會觸發這個方法。onPause()和onResume()是被觸發最頻繁的兩個方法,是以在這裡不應該執行過于消耗資源的方法。

當有其他Activity覆寫了目前Activity時,不論另一個Activity是新開始的還是從下層移至最上層的,目前Activity的onStop()方法都會被觸發。

Activity生命周期的終點。有兩種情況會導緻它被觸發:1)執行了Activity#finish()方法;2)Android系統由于資源不足等原因決定殺掉Activity所在程序。通過isFinishing()方法可以判斷出是哪種情況。在這個方法裡,我們一般要做的事情是釋放Activity占有的資源,例如背景正在進行的下載下傳線程等等。

最後,舉個實際例子來說明,假設你有一個“首頁Activity”和一個“編輯頁Activity”。

當使用者點選首頁裡的“開始編輯”按鈕時,首頁的onPause()->onStart()onStop()依次觸發,編輯頁的onCreate()->onStart()->onResume()依次觸發;(感謝James.H.Fu指出的錯誤)

當使用者在編輯頁按下“傳回”按鈕時,編輯頁的onPause()->onStop()依次觸發,之後首頁的onStart() -> onResume()依次觸發;

這時使用者在首頁按下“傳回”按鈕,首頁的onPause()->onStop()->onDestroy()依次觸發。

參考資料:

<a href="http://developer.android.com/reference/android/app/Activity.html#ActivityLifecycle">Activity Lifecycle</a>

<a href="http://stackoverflow.com/questions/5538312/simplest-android-activity-lifecycle">Simplest Android Activity Lifecycle</a>

<a href="http://ogrelab.ikratko.com/activity-lifecycle-explained-in-details/">Activity lifecycle explained in details</a>

繼續閱讀