Activity启动模式详解(三)--->singleInstance

简介: 以下为第一App MainActivity如下: package cc.testlaunchmode3;import android.os.

以下为第一App

MainActivity如下:

package cc.testlaunchmode3;

import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import android.app.Activity;
import android.content.Intent;
/**
 * Demo描述:
 * Activity加载模式详解
 * 在该Demo中主要讨论singleInstance
 * 
 * 技术描述:
 * Activity有四种加载模式-->
 * 1 standard: 标准(默认)模式
 *   当通过这种模式来启动Activity时,Android总会为目标
 *   Activity创建一个新的实例,并将该Activity添加到当前
 *   Task栈中.注意,这种方式不会启动新的Task,只是将新的
 *   Activity添加到原有的Task
 *   
 * 2 singleTop: Task顶单例模式
 *   该模式和standard模式基本一致,但有一点不同:当将要被
 *   启动的Activity已经位于Task栈顶时,系统不会重新创建
 *   目标Activity实例,而是直接复用Task栈顶的Activity
 *   
 * 3 singleTask: Task内单例模式
 *   采用该加载模式时,Activity在同一个Task内只有一个实例.
 *   当系统采用singleTask模式加载Activity时,又分为以下
 *   三种情况:
 *   (1)如果将要启动的Activity不存在,那么系统将会创建该
 *      实例,并将其加入Task栈顶
 *   (2)如果将要启动的Activity已存在,且存在栈顶,那么此时
 *      与singleTop模式的行为相同
 *   (3)如果将要启动的Activity存在但是没有位于栈顶,那么
 *      此时系统会把位于该Activity上面的所有其他Activity
 *      全部移出Task,从而使得该目标Activity位于栈顶
 *      
 * 4 singleInstance: 全局单例模式
 *   在此种加载模式下,无论从哪个Task中启动目标Activity,只会
 *   创建一个目标Activity实例且会用一个全新的Task栈来装载该
 *   Activity实例.
 *   当系统采用singleInstance模式加载Activity时,又分为以下
 *   两种情况:
 *   (1)如果将要启动的Activity不存在,那么系统将会先创建一个
 *      全新的Task,再创建目标Activity实例并将该Activity实例
 *      放入此全新的Task中
 *   (2)如果将要启动的Activity已存在,那么无论它位于哪个应用
 *      程序,哪个Task中;系统都会把该Activity所在的Task转到
 *      前台,从而使该Activity显示出来
 * 
 * Android对于Activity的管理方式-->
 *   Android采用Task来管理多个Activity.
 *   当启动一个APP时,Android就会为之创建一个Task
 *   然后启动这个应用的入口Activity.
 *   但是Android并没有为Task提供API,开发者无法真正
 *   地访问Task,只能调用Activity的getTaskId()方法来
 *   获取其所在的Task的ID.事实上,我们可以把Task理解成
 *   Activity栈,Task以栈的形式来管理Activity:将不断启
 *   动的Activity压入栈.即:先启动的Activity被放入栈底,
 *   后启动的Activity放在Task栈顶
 * 
 * 测试步骤及解释:
 * 1 进入MainActivity,点击按钮进入AnotherActivity.
 * 2 此时在AnotherActivity界面.此时统将会先创建一个
 *   全新的Task,再创建目标AnotherActivity实例并将
 *   该AnotherActivity实例放入此全新的Task中.请留言
 *   此时得到的TaskID
 * 3 按下Home键
 * 4 运行TestLaunchMode4.在其界面中点击按钮,会启动
 *   TestLaunchMode3中的AnotherActivity.此时会显示
 *   AnotherActivity并且其TaskID没有变化.
 *   
 * 
 * 备注说明:
 * 注意配置文件
 * android:name="cc.testlaunchmode3.MainActivity"
 * android:launchMode="standard"
 * ...............................................
 * <activity 
 *      android:name="cc.testlaunchmode3.AnotherActivity"
 *      android:launchMode="singleInstance"
 *      android:exported="true">
 *         <intent-filter >
 *            <action android:name="cc.testlaunchmode3.AnotherActivity_action"/>
 *            <category android:name="android.intent.category.DEFAULT"/>
 *          </intent-filter>
 * </activity>
 * 
 * 参考资料:
 * Android疯狂讲义(第二版)
 * Thank you very much
 */
public class MainActivity extends Activity {
	private Button mButton;
    private TextView mTextView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
    
	private void init(){
		mTextView=(TextView) findViewById(R.id.textView);
		mTextView.setText("当前Activity:"+"\n"+this.toString()+"\n"+"当前TaskId:"+this.getTaskId());
		mButton=(Button) findViewById(R.id.button);
		mButton.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View view) {
				Intent intent=new Intent(MainActivity.this, AnotherActivity.class);
				startActivity(intent);
			}
		});
	}
	
	

}


AnotherActivity如下:

package cc.testlaunchmode3;

import android.os.Bundle;
import android.widget.TextView;
import android.app.Activity;

public class AnotherActivity extends Activity {
    private TextView mTextView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.another);
		init();
	}
    
	private void init(){
		mTextView=(TextView) findViewById(R.id.textView);
		mTextView.setText("当前Activity:"+"\n"+this.toString()+"\n"+"当前TaskId:"+this.getTaskId());
	}
}


main.mxl如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
   >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Activity加载模式详解" 
        android:layout_centerHorizontal="true"
    />
    
    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="以singleInstance方式启动AnotherActivity" 
        android:layout_centerHorizontal="true"
        android:layout_marginTop="100dip"
        />
    
    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
     />

</RelativeLayout>


another.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
   >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Activity加载模式详解" 
        android:layout_centerHorizontal="true"
    />
    
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="该Activity加载方式为singleInstance" 
        android:layout_centerHorizontal="true"
        android:textSize="20sp"
        android:layout_marginTop="80dip"
    />
    
    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
     />

</RelativeLayout>


AndroidManifest.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="cc.testlaunchmode3"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="14"
        android:targetSdkVersion="14" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="cc.testlaunchmode3.MainActivity"
            android:launchMode="standard"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        
        <activity 
            android:name="cc.testlaunchmode3.AnotherActivity"
            android:launchMode="singleInstance"
            android:exported="true">
            <intent-filter >
                <action android:name="cc.testlaunchmode3.AnotherActivity_action"/>
                <category android:name="android.intent.category.DEFAULT"/>
            </intent-filter>
         </activity>
    </application>

</manifest>


 

 

以下为第二个App

MainActivity如下:

package cc.testlaunchmode4;

import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import android.app.Activity;
import android.content.Intent;

public class MainActivity extends Activity {
	private Button mButton;
    private TextView mTextView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
    
	private void init(){
		mTextView=(TextView) findViewById(R.id.textView);
		mTextView.setText("当前Activity:"+"\n"+this.toString()+"\n"+"当前TaskId:"+this.getTaskId());
		mButton=(Button) findViewById(R.id.button);
		mButton.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View view) {
				Intent intent=new Intent();
				intent.setAction("cc.testlaunchmode3.AnotherActivity_action");
				startActivity(intent);
			}
		});
	}
	
	

}


main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
   >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Activity加载模式详解" 
        android:layout_centerHorizontal="true"
    />
    
    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="以singleInstance方式启动其他应用中的AnotherActivity" 
        android:layout_centerHorizontal="true"
        android:layout_marginTop="100dip"
        />
    
    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
     />

</RelativeLayout>


 

相关文章
|
2月前
|
Android开发
Android学习 —— 测试init.rc中的条件触发的处理顺序
Android学习 —— 测试init.rc中的条件触发的处理顺序
|
6月前
|
Android开发
Activity启动模式完全解读-更新中
Activity启动模式完全解读-更新中
71 0
|
测试技术 Android开发 Python
如何在指定的Activity下进行Monkey测试并控制页面深度
如何在指定的Activity下进行Monkey测试并控制页面深度
|
Android开发
【Android 应用开发】Android 返回堆栈管理 ( 默认启动模式 | 栈顶复用启动模式 | 栈内复用启动模式 | 单实例启动模式 | CLEAR_TOP 标识 )
【Android 应用开发】Android 返回堆栈管理 ( 默认启动模式 | 栈顶复用启动模式 | 栈内复用启动模式 | 单实例启动模式 | CLEAR_TOP 标识 )
214 0
|
Android开发 数据格式 XML
在Activity,Service,Window中监听Home键和返回键的一些思考,如何把事件传递出来的做法!
在Activity,Service,Window中监听Home键和返回键的一些思考,如何把事件传递出来的做法! 其实像按键的监听,我相信很多人都很熟练了,我肯定也不会说这些基础的东西,所以,前期,还是一笔带过一下,我们重点说下后半部分吧 一.
1375 0
|
调度 Android开发
Android5.0L退出APP横竖屏切换导致的触摸屏输入(Touch Event)无效(冻屏)问题分析(Key Event仍然有效)
一、问题现象 1、多次进出需要强制横屏的app,比如Real FootBall2015,在退出app的时候会有概率出现退出卡顿,然后TP无法输入的问题。
2305 0