Activity的四种启动模型

380 阅读2分钟

在 Android 中,Activity 的启动模式(Launch Mode)决定了 Activity 的实例如何与任务栈(Task)关联,主要影响 Activity 的创建和复用行为。通过 AndroidManifest.xml 中的 launchMode 属性或 Intent 的标志位(Flag)可以配置启动模式。以下是四种标准启动模式及其特点:


1. ​standard(标准模式)​

  • 默认模式,每次启动 Activity 都会创建一个新实例,即使该 Activity 已存在。
  • 任务栈​:新实例会放入启动它的 Activity 所在的任务栈中。
  • 典型场景​:普通页面(如新闻详情页),每次打开都需要新实例。
  • 注意​:可能导致栈中多个相同 Activity 实例。
<activity android:name=".MyActivity" android:launchMode="standard" />

2. ​singleTop(栈顶复用模式)​

  • 条件​:如果 Activity 已位于栈顶,则复用该实例(不会创建新实例),并触发 onNewIntent() 方法。
  • 任务栈​:若不在栈顶,仍会创建新实例。
  • 典型场景​:防止重复打开同一个页面(如通知跳转)。
<activity android:name=".MyActivity" android:launchMode="singleTop" />

3. ​singleTask(栈内复用模式)​

  • 条件​:系统会寻找是否存在该 Activity 的任务栈:

    • 如果存在,则复用该实例(触发 onNewIntent()),并清除该实例上方的所有 Activity。
    • 如果不存在,则创建新实例。
  • 任务栈​:通过 taskAffinity 属性可指定独立的任务栈(默认与调用者相同)。

  • 典型场景​:应用主页(如微信主页),保证栈中唯一。

<activity android:name=".MainActivity" android:launchMode="singleTask" />

4. ​singleInstance(单例模式)​

  • 全局唯一​:Activity 独占一个任务栈,且该栈中只有它一个 Activity。
  • 复用规则​:后续请求直接复用该实例(触发 onNewIntent())。
  • 典型场景​:独立运行的页面(如系统拨号盘)。
<activity android:name=".CallActivity" android:launchMode="singleInstance" />

其他启动方式:Intent Flags

除了 launchMode,还可以通过 Intent 的标志位动态控制启动行为:

  • FLAG_ACTIVITY_NEW_TASK​:类似 singleTask,启动新任务栈。
  • FLAG_ACTIVITY_SINGLE_TOP​:类似 singleTop
  • FLAG_ACTIVITY_CLEAR_TOP​:若目标 Activity 已存在,清除其上方所有 Activity。
Intent intent = new Intent(this, MyActivity.class);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intent);

关键区别总结

模式是否创建新实例是否清除栈顶上方任务栈归属
standard总是创建调用者栈
singleTop栈顶时复用调用者栈
singleTask栈内复用可独立栈
singleInstance全局唯一独占新栈

注意事项

  1. 任务栈(Task)​​:Android 通过任务栈管理 Activity 的返回栈,不同应用可能共享或隔离任务栈。
  2. taskAffinity​:通常与 singleTask 配合使用,指定 Activity 的偏好任务栈。
  3. 多进程问题​:避免在 singleInstance 或 singleTask 中滥用,可能导致多进程冲突。

正确选择启动模式可以优化用户体验(如避免页面重复)和内存管理。