您好,登錄后才能下訂單哦!
配置Activity時,可以指定“l(fā)aunchMode”加載模式的屬性,下面記錄一下Android中有關(guān)Activity的四種加載模式。
standard 標準模式
Activity的默認加載模式是”standard“,利用該模式啟動目標Activity時,Android總會為目標Activity創(chuàng)建一個新的實例,并將該Activity添加到當前Task棧中。
下面用代碼來測試一下。分別創(chuàng)建ActivityA、ActivityB,ActivityA代碼如下:
package com.example.activitylaunchmodetest; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; public class ActivityA extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Button btnA = new Button(this); setContentView(btnA); String content = "按鈕A\n\n該Activity所在的taskId為:" + getTaskId(); btnA.setText(content); btnA.setTextSize(50); btnA.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { startActivity(new Intent(ActivityA.this, ActivityB.class)); } }); } }
ActivityB與ActivityA代碼大同小異,只是ActivityB跳轉(zhuǎn)到了自身ActivityB。如下代碼:
startActivity(new Intent(ActivityB.this, ActivityB.class));
在AndroidManifest文件中配置ActivityB,運行程序,點擊按鈕A,跳轉(zhuǎn)到ActivityB,點擊按鈕B,再次跳轉(zhuǎn)到ActivityB,如下圖:
此時當前Task棧中會有兩個ActivityB(如果點擊多次按鈕B,那么會創(chuàng)建多個ActivityB),通過taskid可以看出Activity在同一個Task內(nèi),點擊終端上的back鍵,從第二個ActivityB頁面回退到第一個ActivityB頁面,點擊back鍵,回退到ActivityA頁面,再次點擊back鍵,回退到系統(tǒng)桌面。
singleTop Task頂單例模式
在AndroidManifest文件中配置ActivityB的launchMode為”singleTop“,如下:
<activity android:name="com.example.activitylaunchmodetest.ActivityB" android:label="@string/app_name" android:launchMode="singleTop"> </activity>
運行程序,點擊按鈕A,跳轉(zhuǎn)到ActivityB,點擊按鈕B,不會再做跳轉(zhuǎn),如下圖:
點擊按鈕B時,由于當前ActivityB已經(jīng)位于棧頂,所以系統(tǒng)不會再次創(chuàng)建ActivityB實例,而是直接復(fù)用已存在的ActivityB(調(diào)用自己的onNewIntent(Intent intent)方法)。所以無論點擊多少次按鈕B,Task棧中只會有一個ActivityB。點擊終端上的back鍵,從ActivityB頁面回退到ActivityA頁面,再次點擊back鍵,回退到系統(tǒng)桌面。
我們再創(chuàng)建ActivityC,代碼與ActivityA和ActivityB大同小異,將ActivityB中的代碼修改為跳轉(zhuǎn)到ActivityC,而ActivityC跳轉(zhuǎn)到ActivityB。 在AndroidManifest文件中配置ActivityC,ActivityB的launchMode不變,ActivityA與ActivityC launchMode選擇默認。再次運行程序,分別點擊按鈕A→按鈕B→按鈕C→按鈕B,如下圖。
點擊按鈕C時,由于目標ActivityB不在棧頂,所以系統(tǒng)會再次創(chuàng)建ActivityB實例(多次點擊,ActivityB與ActivityC會交替出現(xiàn)),點擊終端上的back鍵,會經(jīng)過ActivityB→ActivityC→ActivityB→ActivityA→系統(tǒng)桌面。
singleTask Task內(nèi)單例模式
在AndroidManifest文件中修改ActivityB的launchMode為”singleTask“,如下:
<activity android:name="com.example.activitylaunchmodetest.ActivityB" android:label="@string/app_name" android:launchMode="singleTask"> </activity>
運行程序,分別點擊按鈕A→按鈕B→按鈕C,如下圖:
點擊按鈕C跳轉(zhuǎn)到ActivityB時,系統(tǒng)會把位于ActivityB上的所有Activity(此處ActivityC位于ActivityB上,移出ActivityC)都移出Task棧,使目標ActivityB位于棧頂(多次點擊,ActivityC會交替入棧與出棧)。點擊終端上的back鍵,會經(jīng)過ActivityB→ActivityA→系統(tǒng)桌面。
singleInstance 全局單例模式
再次修改ActivityB的launchMode為”singleInstance“,如下:
<activity android:name="com.example.activitylaunchmodetest.ActivityB" android:label="@string/app_name" android:launchMode="singleInstance"> </activity>
運行程序,分別點擊按鈕A→按鈕B→按鈕C→按鈕B→按鈕C,如下圖:
點擊按鈕A跳轉(zhuǎn)到ActivityB時,系統(tǒng)會創(chuàng)建一個新的Task,然后再創(chuàng)建ActivityB實例。點擊按鈕C跳轉(zhuǎn)到ActivityB時,系統(tǒng)會把ActivityB所在的Task轉(zhuǎn)到前臺(根據(jù)taskid可以看出ActivityB和ActivityA、ActivityC不在同一個棧),多次點擊,由于ActivityC還是standard模式,所以會不斷創(chuàng)建,而ActivityB則會不斷轉(zhuǎn)移到前臺,保證全局中只有一個ActivityB,并且它所在的棧中只有自己本身,且位于棧頂。點擊終端上的back鍵,會現(xiàn)將ActivityB從自己棧中移出,再經(jīng)過ActivityC→ActivityC→ActivityA→系統(tǒng)桌面。
注意,如果點擊順序為按鈕A→按鈕B→按鈕C→按鈕B,此時沒有再點擊按鈕C,那么當前棧中最頂端的頁面是ActivityC,點擊back鍵時,會先經(jīng)過ActivityC→ActivityC→ActivityA,將ActivityA與ActivityC從自己的棧中依次移出后,再將ActivityB棧中的ActivityB移出,此時的完整順序為ActivityC→ActivityC→ActivityA→ActivityB→系統(tǒng)桌面。
寫了這么多,最后總結(jié)如下:
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。