Android Activity的生命周期與加載模式超詳細(xì)圖文解析
Activity的生命周期
Activity是安卓應(yīng)用的重要組成單元之一,其對(duì)于安卓的作用類似于Servlet對(duì)于Web應(yīng)用的作用。
整個(gè)Activity生命周期的圖解如下
具體的生命周期可以總結(jié)成如下幾個(gè)步驟
onCreate():Activity啟動(dòng)后第一個(gè)被調(diào)用的函數(shù),常用來(lái)進(jìn)行Activity的初始化,如創(chuàng)建View,綁定數(shù)據(jù)和恢復(fù)數(shù)據(jù)。
onStart():當(dāng)Activity顯示在屏幕上時(shí),函數(shù)被調(diào)用。
onRestart():Activity從停止?fàn)顟B(tài)進(jìn)入活動(dòng)狀態(tài)是調(diào)用。
onResume():Activity可以接受用戶輸入時(shí),該函數(shù)被調(diào)用,此時(shí)的activity位于activity棧的棧頂。
onPause():當(dāng)Activity進(jìn)入暫停狀態(tài)時(shí),該函數(shù)被調(diào)用,一般用來(lái)保存持久的數(shù)據(jù)或釋放占用的資源。
onStop():當(dāng)Activity變?yōu)椴豢梢?jiàn)后,該函數(shù)被調(diào)用,Activity進(jìn)入停止?fàn)顟B(tài)。
onDestroy():在Activity被終止前,被調(diào)用。
歸納起來(lái),Activity大概會(huì)經(jīng)歷四種狀態(tài)
運(yùn)行狀態(tài):當(dāng)前Activity位于前臺(tái),用戶可見(jiàn),可以獲得焦點(diǎn)
暫停狀態(tài):其他Activity位于前臺(tái),該Activity依然可見(jiàn),只是不能獲得焦點(diǎn)
停止?fàn)顟B(tài):該Activity不可見(jiàn),失去焦點(diǎn)
銷毀狀態(tài):該Activity結(jié)束,或Activity所在的進(jìn)程被結(jié)束
我們使用給一個(gè)程序來(lái)看一下看一下Activity的生命周期。程序非常簡(jiǎn)單,就是定義兩個(gè)Activity,分別命名為FirstActivity和SecondActivity,先從FirstActivity跳轉(zhuǎn)到SecondActivity,然后再在SecondActivity銷毀該Activity,最后銷毀FirstActivity
public class FirstActivity extends Activity { final String TAG = "-----FirstActivity-----"; @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.first); // 輸出日志 Log.d(TAG, "-----onCreate-----"); TextView textView = findViewById(R.id.text1); Button button1 = findViewById(R.id.bn_first1); Button button2 = findViewById(R.id.bn_first2); // 第一個(gè)按鈕跳轉(zhuǎn)到第二個(gè)Activity button1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(FirstActivity.this, SecondActivity.class); startActivity(intent); } }); // 第二個(gè)按鈕銷毀該Activity button2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { FirstActivity.this.finish(); } }); } @Override protected void onStart() { super.onStart(); Log.d(TAG, "-----onStart-----"); } @Override protected void onRestart() { super.onRestart(); Log.d(TAG, "-----onRestart-----"); } @Override protected void onResume() { super.onResume(); Log.d(TAG, "-----onResume-----"); } @Override protected void onPause() { super.onPause(); Log.d(TAG, "-----onPause-----"); } @Override protected void onStop() { super.onStop(); Log.d(TAG, "-----onStop-----"); } @Override protected void onDestroy() { super.onDestroy(); Log.v(TAG, "-----onDestory-----"); } }
public class SecondActivity extends Activity { @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.second); Button button = findViewById(R.id.bn_second); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { SecondActivity.this.finish(); } }); } }
最后得到的日志信息如下所示,我們過(guò)濾了其他日志,只保留FirstActivity的日志
Activity的加載模式
Activity一共有四種加載模式
- standard:標(biāo)準(zhǔn)模式,這是默認(rèn)的加載模式
- singleTop:Task棧頂單例模式
- singleTask:Task內(nèi)單例模式
- singleInstance:全局單例模式
安卓采用Task來(lái)管理多個(gè)Activity,當(dāng)我們啟動(dòng)應(yīng)用的時(shí)候,安卓就會(huì)位置創(chuàng)建一個(gè)Task,然后啟動(dòng)這個(gè)引用的入口Activity,(即<intent-filter>中配置為MAIN和LAUNCHER的Activity)。
我們可以將Task簡(jiǎn)單理解成存放Activity的棧,先加載的Activity位于棧底,后加載的Activity位于棧頂。
Activity的加載模式就是按照什么樣的方式去實(shí)例化,加載Activity,并且控制Activity和Task之間的關(guān)系。
standard模式
當(dāng)我們通過(guò)standard模式啟動(dòng)Activity的時(shí)候,每次都會(huì)創(chuàng)建一個(gè)新的Activity示例放置到棧頂。當(dāng)我們?cè)谂渲肁ctivity時(shí)沒(méi)有指定加載模式的時(shí)候,采用的就是standard模式。
singleTop模式
這種模式與standard模式基本相同,唯一不同的就是,當(dāng)要啟動(dòng)的Activity已經(jīng)位于棧頂?shù)臅r(shí)候不會(huì)創(chuàng)建一個(gè)新的實(shí)例,而是復(fù)用已有的實(shí)例。如果我們的目標(biāo)Activity不位于棧頂,那么還是會(huì)創(chuàng)建一個(gè)新的實(shí)例,這一點(diǎn)和standard模式是一樣的。
singleTask模式
采用singleTask模式的Activity在同一個(gè)Task中只有一個(gè)實(shí)例,當(dāng)系統(tǒng)采用singleTask模式啟動(dòng)目標(biāo)Activity的時(shí)候,可分為如下三種情況
如果要啟動(dòng)的Activity實(shí)例不存在,系統(tǒng)會(huì)創(chuàng)建一個(gè)實(shí)例,并且將其置于棧頂
如果要啟動(dòng)的Activity實(shí)例位于棧頂,此時(shí)的操作與singleTop模式相同
如果要啟動(dòng)的Activity實(shí)例存在于棧中,但是沒(méi)有位于棧頂,那么系統(tǒng)就會(huì)將該Activity上的所有Activity移出Task棧,從而使目標(biāo)Activity轉(zhuǎn)入棧頂
singleInstance模式
在這種加載模式下,系統(tǒng)保證無(wú)論從哪個(gè)Task中啟動(dòng)目標(biāo)Activity,只會(huì)創(chuàng)建一個(gè)目標(biāo)Activity實(shí)例,并會(huì)使用一個(gè)全新的Task棧來(lái)加載該Activity實(shí)例。
當(dāng)系統(tǒng)采用singleInstance模式啟動(dòng)目標(biāo)Activity時(shí),可分為如下兩種情況
如果要啟動(dòng)的目標(biāo)Activity不存在,系統(tǒng)會(huì)創(chuàng)建一個(gè)全新的Task,再創(chuàng)建目標(biāo)Activity的實(shí)例,并將它加入到新的Task棧頂
如果要啟動(dòng)的目標(biāo)Activity已經(jīng)存在,無(wú)論它位于哪個(gè)應(yīng)用程序中,位于哪個(gè)Task中,系統(tǒng)都會(huì)把該Activity所在的Task轉(zhuǎn)到前臺(tái),從而使該Activity顯示出來(lái)
到此這篇關(guān)于Android Activity的生命周期與加載模式超詳細(xì)圖文解析的文章就介紹到這了,更多相關(guān)Android Activity的生命周期內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Visual Studio上構(gòu)建C++的GUI框架wxWidgets的開(kāi)發(fā)環(huán)境
這篇文章主要介紹了Visual Studio上構(gòu)件C++的GUI框架wxWidgets開(kāi)發(fā)環(huán)境的方法,wxWidgets是一個(gè)跨多個(gè)系統(tǒng)平臺(tái)的圖形化界面開(kāi)發(fā)框架,并且可用語(yǔ)言不限于C++,需要的朋友可以參考下2016-04-04Android中使用Service實(shí)現(xiàn)后臺(tái)發(fā)送郵件功能實(shí)例
這篇文章主要介紹了Android中使用Service實(shí)現(xiàn)后臺(tái)發(fā)送郵件功能的方法,結(jié)合實(shí)例形式分析了Service實(shí)現(xiàn)郵件的發(fā)送、接收及權(quán)限控制相關(guān)技巧,需要的朋友可以參考下2016-01-01OpenGL ES正交投影實(shí)現(xiàn)方法(三)
這篇文章主要為大家詳細(xì)介紹了OpenGL ES正交投影的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05app 請(qǐng)求服務(wù)器json數(shù)據(jù)實(shí)例代碼
下面小編就為大家分享一篇app 請(qǐng)求服務(wù)器json數(shù)據(jù)實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Android實(shí)現(xiàn)EditText的富文本編輯
這篇文章主要介紹了Android實(shí)現(xiàn)EditText的富文本編輯,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08