`

Android中Activity启动模式详解

 
阅读更多

 

Android中Activity启动模式详解

 

  在Android中每个界面都是一个Activity,切换界面操作其实是多个不同Activity之间的实例化操作。在Android中Activity的启动模式决定了Activity的启动运行方式。

  Android总Activity的启动模式分为四种:

 

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

Activity的四种启动模式:
. standard

        模式启动模式,每次激活Activity时都会创建Activity,并放入任务栈中。
. singleTop

        如果在任务的栈顶正好存在该Activity的实例, 就重用该实例,否者就会创建新的实例并放入栈顶(即使栈中已经存在该Activity实例,只要不在栈顶,都会创建实例)。
. singleTask

        如果在栈中已经有该Activity的实例,就重用该实例(会调用实例的onNewIntent())。重用时,会让该实例回到栈顶,因此在它上面的实例将会被移除栈。如果栈中不存在该实例,将会创建新的实例放入栈中。 
. singleInstance

        在一个新栈中创建该Activity实例,并让多个应用共享改栈中的该Activity实例。一旦改模式的Activity的实例存在于某个栈中,任何应用再激活改Activity时都会重用该栈中的实例,其效果相当于多个应用程序共享一个应用,不管谁激活该Activity都会进入同一个应用中。
 

 

 其中standard是系统默认的启动模式。

 

private TextView text_show;
     private Button btn_mode;
     
     @Override
     public void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
         
         text_show = (TextView) this.findViewById(R.id.text_show);
         
         text_show.setText(this.toString());
         
         btn_mode = (Button) this.findViewById(R.id.btn_mode);
         
     }
     
    //按钮单击事件
     public void LaunchStandard(View v){
         startActivity(new Intent(this,MainActivity.class));
         
         text_show.setText(this.toString());
     }
 

 

 初始化界面如下:



 

当点击按钮时,会创建新的Activity,通过TextView@后16进制数的显示即可看出,点击两次分别界面如下:




 

 此时,我们分析栈内部的运行机制:

   (依次从栈顶向上)



 

因此,这种Standard模式是每次都会创建新的Activity对象,当点击返回按钮时,他会将栈顶(当前Activity)消灭,然后跳到下一层,例如如果现在Activity是44ed8c50,那么当我们点击返回时Activity会变为44f28a48,不过此时在这个Activity中再次点击按钮创建对象时,它会另外创建新的Activity对象,这种模式可能大多数情况下不是我们需要的,因为对系统性能的消耗过大。

  下面我们介绍两种能使用当前栈中Activity的启动模式:

  2. singleTop

    从上面的解释中即可知道,在每次使用新的Activity时会自动检测栈顶的当前Activity是否是需要引用的Activity,如果是则直接引用此Activity,而不会创建新的Activity。

    我们在刚才的界面中加入一个"启动singletop模式"按钮,当点击时出现我们创建的singletop中,在Activity singletop中有一个按钮,启动singletop模式,表示启动当前Activity,由于我们在清单文件中配置Activity的启动模式为singleTop,因此此时不会再创建而是利用当前栈顶的singleTop Activity:

<activity
            android:name=".SingleTopActivity"
            android:label="@string/singletop"
            android:launchMode="singleTop" >
        </activity>

 

界面初始化:



 

点击"启动singleTop模式"按钮:



 

我们分析它的运行机制,可知,当程序运行到此时,栈中的数据形式为:



 

 

   当我们在上面界面中点击"启动singleTop模式"按钮时,由于此Activity设置的启动模式为singleTop,因此它首先会检测当前栈顶是否为我们要请求的Activity对象,经验证成立,因此它不会创建新的Activity,而是引用当前栈顶的Activity。



 

虽然它不会创建新的Activity对象,不过它每次回调用onNewIntent()方法:

@Override
     protected void onNewIntent(Intent intent) {
         // TODO Auto-generated method stub
         super.onNewIntent(intent);
         
         Toast.makeText(this, new Date().toString(), 1).show();
     }

 

   我们为此方法编写代码输出当前日期,则在每次点击上面按钮时会输出当前日期。

 

  3.singleTask

    此启动模式和singleTop在名字上即可看出区别,即singleTop每次只检测当前栈顶的Activity是否是我们需要请求创建的,而singleTask则会检测栈中全部的Activity对象,从上向下,如果检测到是我们所请求的则会消灭此Activity对象上面的对象,直接把检测到的我们需要的Activity置为栈顶。

    我们创建一个SingleTaskActivity,此界面中包含一个启动MainActivity和启动SingleTaskActivity按钮。

  初始化:



 

点击"启动singleTask模式"按钮:



 

 

在此界面中点击第二个按钮"启动singleTask模式"按钮,根据定义会检测当前栈中是否有此Activity对象,因此显示的还是当前的Activity,不会重新创建;

  再点击"启动Standard模式"按钮,由于MainActivity的启动模式为standard,所以在此会重新创建一个MainActivity对象:



 

此时栈中数据格式为:

 



 

 当在上面界面中点击"启动singleTask模式"按钮时,由于检测到当期栈中第二个为我们要创建的Activity,会将最上面的MainActivity消灭,然后将SingleTaskActivity设置为栈顶:




  4.SingleInstance

    此启动模式和我们使用的浏览器工作原理类似,我们都知道在多个程序中访问浏览器时,如果当前浏览器没有打开,则打开浏览器,否则会在当前打开的浏览器中访问。此模式会节省大量的系统资源,因为他能保证要请求的Activity对象在当前的栈中只存在一个。

 

    

    上面即为Android中的四种启动模式,我们在开发Android项目时会经常使用到,巧妙设置Activity的启动模式会节省系统开销和程序运行效率。

 

 

  • 大小: 15.1 KB
  • 大小: 14.6 KB
  • 大小: 15.3 KB
  • 大小: 17.9 KB
  • 大小: 20.2 KB
  • 大小: 17.6 KB
  • 大小: 9.3 KB
  • 大小: 17.6 KB
  • 大小: 25.2 KB
  • 大小: 23.2 KB
  • 大小: 25.4 KB
  • 大小: 11.3 KB
  • 大小: 23.4 KB
1
3
分享到:
评论

相关推荐

    android activity启动模式详解

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

    Android中Activity四种启动模式和taskAffinity属性详解-Rong

    为了管理Activity的生命周期和用户界面的流程,Android系统提供了一系列的机制和属性,其中包括四种不同的Activity启动模式以及taskAffinity属性。这些启动模式和属性共同作用于Activity所属的任务栈(Task)和后退...

    android Activity的启动模式 作用简析+demo详解

    此篇博客意在让对启动模式不了解的开发者对其有一个较为形象的认识,至于深入探究,笔者还是推荐去看任玉刚前辈所写的《android开发艺术探索》了。 网上对Activity的启动模式讲解的博客有很多,但是大部分都需要掌握...

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

    ### Android Activity 的四种启动模式与 Intent.setFlags()详解 #### 一、Android Activity 四种启动模式 在 Android 应用开发中,Activity 是构成应用的基本单元之一,它负责显示用户界面并处理用户交互。为了更...

    android Activity生命周期详解(图文)

    不同的启动模式会影响Activity在任务栈中的位置,从而影响其生命周期行为。例如,SingleTop模式下,如果新启动的Activity已经在栈顶,系统不会创建新的实例,而是调用`onNewIntent()`。 总之,深入理解Activity生命...

    Android Activity启动模式之singleTop实例详解

    在前面文章《Android Activity启动模式之standard实例详解》中,我们介绍了活动的默认启动模式standard,本文继续介绍Activity的singleTop模式。 singleTop模式:当Activity的活动模式设置为singleTop时,在启动活动...

    Android Activity启动模式之standard实例详解

    本文实例讲述了Android Activity启动模式之standard。分享给大家供大家参考,具体如下: Android的活动是通过任务Task来进行管理的,一个任务就是一组放在栈里的活动的集合,即所谓的返回栈(Back Stack)。栈具有...

    activity启动模式

    ### Activity启动模式详解 #### 一、Android进程与线程模型概述 在深入了解Activity启动模式之前,我们首先需要对Android的进程与线程模型有一个基本的认识。这将有助于更好地理解Activity是如何在不同的环境下...

    Android动态加载Activity原理详解

    `ActivityInfo`包含了Activity的元数据,如启动模式、主题等,而`loadedApk`则包含了与应用相关的所有信息,如类加载器、资源等。 在启动过程中,`ActivityClientRecord`的`packageInfo`字段起初为null,需要通过`...

    详解 Android 的 Activity 组件

    在实际开发中,合理地运用Activity的启动模式(standard、singleTop、singleTask、singleInstance)可以解决许多复杂场景的问题。 最后,关于EX01这个压缩包文件,可能包含了一些示例代码或练习项目,用于辅助学习...

    Android的Activity的Launch模式之Standard案例

    本篇将详细讲解"Standard"模式,这是Activity启动模式中最基础的一种。 1. **Standard模式详解** Standard模式是Activity的默认启动模式。在该模式下,每次启动Activity时,系统都会创建一个新的实例,并将其压入...

    详解教程Android开发中的Activity 组件

    ### 详解Android开发中的Activity组件 #### 概述 在Android开发中,`Activity`是四大组件之一,扮演着至关重要的角色。它负责提供用户界面并处理与用户的交互,每一个`Activity`通常对应一个屏幕。本文将深入探讨`...

    Android Activity启动模式之singleTask实例详解

    本文实例分析了Android Activity启动模式之singleTask。分享给大家供大家参考,具体如下: 前面的文章介绍了Android 活动Activity的启动模式:standard 和singleTop 。本文继续介绍Activity的下一个启动模式:...

Global site tag (gtag.js) - Google Analytics