詳解Activity之singletast啟動模式及如何使用intent傳值
Activity的四種啟動模式:
1. standard
模式啟動模式,每次激活A(yù)ctivity時都會創(chuàng)建Activity,并放入任務(wù)棧中。
2. singleTop
如果在任務(wù)的棧頂正好存在該Activity的實(shí)例, 就重用該實(shí)例,否者就會創(chuàng)建新的實(shí)例并放入棧頂(即使棧中已經(jīng)存在該Activity實(shí)例,只要不在棧頂,都會創(chuàng)建實(shí)例)。
3. singleTask
如果在棧中已經(jīng)有該Activity的實(shí)例,就重用該實(shí)例(會調(diào)用實(shí)例的onNewIntent())。重用時,會讓該實(shí)例回到棧頂,因此在它上面的實(shí)例將會被移除棧。如果棧中不存在該實(shí)例,將會創(chuàng)建新的實(shí)例放入棧中。
4. singleInstance
在一個新棧中創(chuàng)建該Activity實(shí)例,并讓多個應(yīng)用共享改棧中的該Activity實(shí)例。一旦改模式的Activity的實(shí)例存在于某個棧中,任何應(yīng)用再激活改Activity時都會重用該棧中的實(shí)例,其效果相當(dāng)于多個應(yīng)用程序共享一個應(yīng)用,不管誰激活該Activity都會進(jìn)入同一個應(yīng)用中。
因?yàn)轫?xiàng)目中,有一個消息推送的功能,每次推送一個消息,就會開啟FunctionActivity,那么為了避免重復(fù)開啟它,在退后的時候,多次出現(xiàn)該Activity,就將該Activity的啟動模式變?yōu)閟ingleTask。
這樣在之后的多次啟動該Activity,便會調(diào)用onNewIntent(Intent intent)方法。
activity通過intent傳遞數(shù)據(jù)的時候,如果activity未啟動,那么 在這個剛啟動的activity里通過getIntent()會獲取到這個intent的數(shù)據(jù).如果要啟動的activity是已經(jīng)存在的,這時候通過 getInten()方法獲取到的intent是已啟動的activity的原始intent.換句話說intent的數(shù)據(jù)沒有更新.這樣在已啟動的 activity里拿到的intent的數(shù)據(jù)是舊數(shù)據(jù).如果要每次獲取intent傳來的新數(shù)據(jù)就需要在onNewIntent(Intent intent)方法里調(diào)用setIntent(intent)設(shè)置這個傳來的最新的intent.如下所示:
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
Log.e("tag", "onNewINtent執(zhí)行了");
setIntent(intent);
String ringName = intent.getStringExtra("ringName");
Log.e("tag", ringName+"傳過來的值");
if (ringName != null) {
pager.setCurrentItem(1);
}
}
當(dāng)然,如果activity的啟動模式是standard,那么每次都重新創(chuàng)建一個新的activity.這樣intent也是最新的.就不用通過setIntent來更新這個intent.
我這個項(xiàng)目中,F(xiàn)unctionActivity中里面是四個Fragment,這樣 我從其他Activity跳轉(zhuǎn)到FunctionActivity是不會實(shí)例化,通過getIntent()方法也不能獲得最新的intent,為了解決 這個辦法。還是在onNewIntent方法中,將更新的intent通過getIntent().putExtras(intent);共享出去,如下 所示:
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
Log.e("tag", "onNewINtent執(zhí)行了");
setIntent(intent);
getIntent().putExtras(intent);
}
這樣在與它關(guān)聯(lián)的Fragment中,就可以調(diào)用
@Override
public void onResume() {
super.onResume();
// 第一次進(jìn)入這個頁面,下面的方法是不會執(zhí)行的,因?yàn)閞ingName是null
String ringName = getActivity().getIntent().getStringExtra("ringName");
if (ringName != null) {
newSound.setText(ringName);
Log.e("tag", ringName + "要保存的值");
SharedPreferenceUtil.setString(getActivity(),
SharedPreferenceUtil.RINGTONE_NAME, ringName);
}
}
注意,這里Fragment調(diào)用的時候,一定要在onResume方法中。
- Android Activity啟動模式之singleTop實(shí)例詳解
- Android Activity啟動模式之singleTask實(shí)例詳解
- Activity 四種啟動模式詳細(xì)介紹
- 簡單介紹Android中Activity的四種啟動模式
- Android入門之Activity四種啟動模式(standard、singleTop、singleTask、singleInstance)
- Android Activity啟動模式之standard實(shí)例詳解
- Android中Activity生命周期和啟動模式詳解
- 如何正確理解和使用Activity的4種啟動模式
- Android Activity啟動模式全面解析
- Android Activity的4種啟動模式圖文介紹
相關(guān)文章
Android中制作進(jìn)度框和環(huán)形進(jìn)度條的簡單實(shí)例分享
這篇文章主要介紹了Android中制作進(jìn)度框和環(huán)形進(jìn)度條的簡單實(shí)例分享,環(huán)形進(jìn)度條帶有基本的百分比顯示,需要的朋友可以參考下2016-03-03
Android實(shí)現(xiàn)類似360,QQ管家那樣的懸浮窗
用到的就是WindowManager以及WindowManager.LayoutParams,對這個LayoutParams做文章,當(dāng)設(shè)置為屬性后,然后,創(chuàng)建一個View,將這個View添加到WindowManager中就行2013-06-06
Android實(shí)現(xiàn)WebView點(diǎn)擊攔截跳轉(zhuǎn)原生
這篇文章主要介紹了Android實(shí)現(xiàn)WebView點(diǎn)擊攔截跳轉(zhuǎn)原生,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
Android懸浮對話框(即點(diǎn)即關(guān)對話框)實(shí)現(xiàn)代碼
本文給大家介紹android懸浮對話框和即點(diǎn)即關(guān)閉對話框,本文介紹非常詳細(xì),具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧2016-03-03
Android開發(fā)中MJRefresh自定義刷新動畫效果
本文給大家介紹了MJRefresh自定義刷新動畫效果,包括常見用法等相關(guān)知識,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧2016-11-11
Android實(shí)現(xiàn)為ListView同時設(shè)置點(diǎn)擊時的背景和點(diǎn)擊松手之后的背景
這篇文章主要介紹了Android實(shí)現(xiàn)為ListView同時設(shè)置點(diǎn)擊時的背景和點(diǎn)擊松手之后的背景,以實(shí)例形式較為詳細(xì)的分析了界面元素與功能的實(shí)現(xiàn)技巧,非常具有實(shí)用價值,需要的朋友可以參考下2015-02-02

