`
chriszeng87
  • 浏览: 742319 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Activity的启动模式(android:launchMode)

阅读更多

转自:http://blog.csdn.net/feng88724/article/details/6412638

在android里,有4种activity的启动模式,分别为:

“standard” (默认)

“singleTop”

“singleTask”

“singleInstance”

 

它们主要有如下不同:

 

1. 如何决定所属task

“standard”和”singleTop”的activity的目标task,和收到的Intent的发送者在同一个task内,除非intent包括参数FLAG_ACTIVITY_NEW_TASK。

如果提供了FLAG_ACTIVITY_NEW_TASK参数,会启动到别的task里。

“singleTask”和”singleInstance”总是把activity作为一个task的根元素,他们不会被启动到一个其他task里。

 

此话描述不正确, 感谢 liuluxu1989 提出。

这篇博文写的比较简单, 也没有任何图示, 不便大家理解, 建立大家直接看Dev guide.  或者下面这篇博文:

http://marshal.easymorse.com/archives/2950

 

2. 是否允许多个实例

“standard”和”singleTop”可以被实例化多次,并且存在于不同的task中,且一个task可以包括一个activity的多个实例;

“singleTask”和”singleInstance”则限制只生成一个实例,并且是task的根元素。

singleTop要求如果创建intent的时候栈顶已经有要创建 的Activity的实例,则将intent发送给该实例,而不发送给新的实例。

 

3. 是否允许其它activity存在于本task内

“singleInstance”独占一个task,其它activity不能存在那个task里;如果它启动了一个新的activity,不管新的activity的launch mode 如何,新的activity都将会到别的task里运行(如同加了FLAG_ACTIVITY_NEW_TASK参数)。

而另外三种模式,则可以和其它activity共存。

 

4. 是否每次都生成新实例

“standard”对于没一个启动Intent都会生成一个activity的新实例;

“singleTop”的activity如果在task的栈顶的话,则不生成新的该activity的实例,直接使用栈顶的实例,否则,生成该activity的实例。

比如现在task栈元素为A-B-C-D(D在栈顶),这时候给D发一个启动intent,如果D是 “standard”的,则生成D的一个新实例,栈变为A-B-C-D-D。

如果D是singleTop的话,则不会生产D的新实例,栈状态仍为A-B-C-D

如果这时候给B发Intent的话,不管B的launchmode是”standard” 还是 “singleTop” ,都会生成B的新实例,栈状态变为A-B-C-D-B。

 

“singleInstance”是其所在栈的唯一activity,它会每次都被重用。

 

“singleTask”如果在栈顶,则接受intent,否则,该intent会被丢弃,但是该task仍会回到前台。

 

当已经存在的activity实例处理新的intent时候,会调用onNewIntent()方法

如果收到intent生成一个activity实例,那么用户可以通过back键回到上一个状态;如果是已经存在的一个activity来处理这个intent的话,用户不能通过按back键返回到这之前的状态。

 

 

 


该文来自网络,源地址已经忘了, 原作者可以与我联系,以注明版权!

 

总结:

standard  每次都会新建,每个Task都可以有,且每个Task都可以有多个实例(每个Task都可以有,且可以有多个)
singleTop 当前实例如果在栈顶,就不新建实例,调用其OnNewIntent。 如不在栈顶,则新建实例 (每个Task都可以有,且可以有多个,在栈顶时可复用)
singleTask 新建一个Task,如果已经有其他的Task并且包含该实例,那就直接调用那个Task的实例。(只有一个Task中会有)
singleInstance 新建一个Task,且在该Task中只有它的唯一一个实例。 (只有一个Task会有,且该Task中只有它)


FLAG_ACTIVITY_NEW_TASK  类似singleTask
FLAG_ACTIVITY_SINGLE_TOP 类似singleTop 
FLAG_ACTIVITY_CLEAR_TOP 无对应

 

配两个图,我觉得很清晰:

(1)standard  

 

(2)singleTask

可以将TaskA TaskB理解为两个应用,比如TaskA是你当前的应用,TaskB是默认浏览器。

当到了TaskB中后,按返回键,需要先在TaskB中返回到root,然后才能返回到TaskA。

 

 

总结成以下几句

 

[plain] view plaincopyprint?
 
  1. standard  每次都会新建,每个Task都可以有,且每个Task都可以有多个实例(每个Task都可以有,且可以有多个)  
  2. singleTop 当前实例如果在栈顶,就不新建实例,调用其OnNewIntent。 如不在栈顶,则新建实例  (每个Task都可以有,且可以有多个,在栈顶时可复用)  
  3. singleTask 新建一个Task,如果已经有其他的Task并且包含该实例,那就直接调用那个Task的实例。(只有一个Task中会有)  
  4. singleInstance 新建一个Task,且在该Task中只有它的唯一一个实例。 (只有一个Task会有,且该Task中只有它)  
分享到:
评论

相关推荐

    Android代码-Android 一些重要知识点解析整理

    Activity 的启动模式(android:launchMode) Android Activity 的四种启动模式 管理Activity的生命周期 Android入门:Activity四种启动模式 Android Intent Android中Intent传递对象的两种方法...

    android Activity启动模式(launchMode)

    一、Activity启动模式概述 Activity的启动模式主要分为四种: 1. standard(标准模式):每次启动都会创建一个新的Activity实例,不论栈中是否存在该Activity。 2. singleTop(栈顶复用模式):如果新启动的Activity...

    Android Activity LaunchMode 验证

    在Android应用开发中,Activity是用户界面的基本单元,而LaunchMode是控制Activity启动行为的关键配置。本主题将深入探讨Android Activity的LaunchMode,以及如何通过分析AndroidManifest.xml和实际编码来验证其工作...

    android中的Activity启动方式

    Activity启动模式设置: <activity android:name=".MainActivity"android:launchMode="standard" /> Activity的四种启动模式: 1.standard 模式启动模式,每次激活Activity时都会创建Activity,并放入任务栈中。 ...

    Android launchMode学习例子

    在Android应用开发中,`launchMode`是Activity的重要属性,它定义了系统如何启动和管理Activity实例。通过设置不同的`launchMode`,开发者可以控制Activity的行为,以满足不同场景的需求。本篇将深入探讨Android `...

    android中launchMode四种启动方法详解.pdf

    在Android开发中,Activity的启动模式(launchMode)是一个关键概念,它决定了当用户通过Intent启动一个Activity时,系统如何管理Activity的实例。本篇主要介绍Android中的四种启动模式:standard、singleTop、...

    android activity启动模式详解

    了解和掌握不同的Activity启动模式对于优化应用程序的行为至关重要。本文将详细讲解四种主要的Activity启动模式:standard、singleTop、singleTask以及singleInstance,并通过实际案例分析它们的应用场景。 1. ...

    Activity启动模式实验代码

    一、Activity启动模式概述 1. **标准模式(Standard)**:这是Activity的默认启动模式,每次启动都会创建一个新的实例,无论是否已在栈中存在。因此,同一个Activity可能会有多个实例。 2. **单实例模式...

    android的Activity启动模式

    本文将深入探讨Android的四种Activity启动模式:标准模式(Standard)、单实例模式(SingleInstance)、单任务模式(SingleTask)和单栈顶模式(SingleTop),并结合实际代码示例进行详细解析。 1. 标准模式...

    LaunchMode的使用

    Activity是Android最常用的组件之一,也是最直观的组件,Activity启动时有四种模式,分别是: “standard” "singleTop" "singleTask" "singleInstance" 其中"standard"是默认模式。

    android 退出app 退出应用程序

    2 设置入口activity的启动模式android:launchMode="singleTask",重写onNewIntent方法, 在退出activity时,设置intent.setAction("exit_app");然后跳转到栈底activity, 这样就可以清除栈底之外的所有activity,...

    Activity启动模式

    Activity的启动模式是Android系统管理Activity实例的关键特性,它决定了如何创建和管理Activity的生命周期。本篇将深入探讨Activity的四种启动模式:标准模式(Standard)、单实例模式(SingleInstance)、单任务...

    Android Activity LaunchMode Test

    当从standard Activity启动singleTop Activity时,根据不同的LaunchMode,观察Activity实例数量和onNewIntent()的调用情况。 4. **实际应用** - **standard**:适用于没有特定启动需求的Activity,如常见的导航...

    Android入门之Activity四种启动模式(standard、singleTop、singleTask、singleInstance)

    Activity启动模式的设置在AndroidManifest.xml文件中,通过配置Activity的属性android:launchMode=””设置。 一、启动模式介绍  启动模式简单地说就是Activity启动时的策略,在AndroidManifest.xml中的标签的...

    Android Activity LaunchMode例子

    Android提供了四种LaunchMode:standard、singleTop、singleTask和singleInstance,它们分别对应不同的启动策略。 2. standard(默认模式) 在standard模式下,每次启动Activity都会创建一个新的实例,无论当前栈中...

    Android各种超炫特效 Activity启动模式

    本篇文章将深入探讨Android中的四种主要Activity启动模式:标准模式(Standard)、单实例模式(SingleTop)、单任务模式(SingleTask)和单栈顶模式(SingleActivity)。 1. **标准模式(Standard)**:这是...

    Android Activity 的四种启动模式 lunchMode 和 Intent.setFlags()

    这些启动模式可以通过在 AndroidManifest.xml 文件中为 Activity 设置 `android:launchMode` 属性来指定。 ##### 1. Standard 模式 (默认模式) - **描述**:当 Activity 的启动模式设置为 `standard` 时,每次通过...

    Android LaunchMode启动方法

    启动模式可以通过在AndroidManifest.xml文件中为Activity配置`android:launchMode`属性来指定: ```xml <activity android:name=".ActB" android:launchMode="singleTask"> </activity> ``` 此外,也可以在IDE...

    详解Android开发中Activity的四种launchMode

    本文将深入探讨Android中的四种Activity启动模式:standard、singleTop、singleTask和singleInstance。 1. **standard**: 这是Activity的默认启动模式。每次使用Intent启动Activity时,系统都会创建一个新的...

Global site tag (gtag.js) - Google Analytics