Activity四种启动模式

本文详细介绍了Android中Activity的四种启动模式:Standard、SingleTop、SingleTask和SingleInstance。每种模式在启动Activity时的行为不同,涉及栈内Activity的创建和销毁。Standard模式每次都会创建新的Activity对象,SingleTop模式只会创建栈顶匹配的Activity,SingleTask模式会消除栈中匹配Activity上面的所有Activity,而SingleInstance模式则会在单独的栈中创建唯一实例的Activity。
摘要由CSDN通过智能技术生成

模式一:

                   Standard:每次激活Activity时都会重新创建一个Activity对象

代码部分:

                  在Manifest文件中注册:<activity android:name=".MainActivity" android:launchMode="standard" />

  1. private TextView text_show;  
  2.      private Button btn_mode;  
  3.        
  4.      @Override  
  5.      public void onCreate(Bundle savedInstanceState) {  
  6.          super.onCreate(savedInstanceState);  
  7.          setContentView(R.layout.activity_main);  
  8.            
  9.          text_show = (TextView) this.findViewById(R.id.text_show);  
  10.            
  11.          text_show.setText(this.toString());  
  12.            
  13.          btn_mode = (Button) this.findViewById(R.id.btn_mode);  
  14.            
  15.      }  
  16.        
  17.     //按钮单击事件  
  18.      public void LaunchStandard(View v){  
  19.          startActivity(new Intent(this,MainActivity.class));  
  20.            
  21.          text_show.setText(this.toString());  
  22.      }  
初始化界面如下:

  

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

  

   

  

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

   (依次从栈顶向上)

 

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


模式二:

                    SingleTop:每次激活Activity时,如果栈顶的Activity就是要激活的对象,则直接激活不用创建;否则重新创建

代码部分:

                   在Manifest文件中注册:<activity android:name=".MainActivity" android:launchMode="singletop" />

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

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

[html]  view plain  copy
  1. <activity  
  2.             android:name=".SingleTopActivity"  
  3.             android:label="@string/singletop"  
  4.             android:launchMode="singleTop" >  
  5. </activity>  

    界面初始化:

      

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

          

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

    

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

       

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

[java]  view plain  copy
  1. @Override  
  2.      protected void onNewIntent(Intent intent) {  
  3.          // TODO Auto-generated method stub  
  4.          super.onNewIntent(intent);  
  5.            
  6.          Toast.makeText(thisnew Date().toString(), 1).show();  
  7.      }  

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

模式三:

                    SingleTask:每次激活Activity时查看栈中是存在要被激活的对象,如果存在则直接激活(在它之上的activity在激活的时                                              候全部销毁),否则重新创建

代码部分:

                    在Manifest文件中注册:<activity android:name=".MainActivity" android:launchMode="singletask" />

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

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

  初始化:

    

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

    

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

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

    

  此时栈中数据格式为:

    

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

    


模式四:

                SingleInstance:在一个新栈中创建实例,其它应用共享这一个实例

               在Manifest文件中注册:<activity android:name=".MainActivity" android:launchMode="singleinstance" />

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

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值