onNewIntent调用时机

来源:互联网 发布:g3110扫描仪软件 编辑:程序博客网 时间:2024/06/15 13:57

在IntentActivity中重写下列方法:onCreateonStart onRestart  onResume  onPause onStop onDestroy onNewIntent

如果IntentActivity处于任务栈的顶端,也就是说之前打开过的Activity,现在处于

 

I/@@@philn(12410): onPause
I/@@@philn(12410): onStop 状态的话
其他应用再发送Intent的话,执行顺序为:
I/@@@philn(12410): onNewIntent
I/@@@philn(12410): onRestart
I/@@@philn(12410): onStart
I/@@@philn(12410): onResume

在Android应用程序开发的时候,从一个Activity启动另一个Activity并传递一些数据到新的Activity上非常简单,但是当您需要让后台运行的Activity回到前台并传递一些数据可能就会存在一点点小问题。

首 先,在默认情况下,当您通过Intent启到一个Activity的时候,就算已经存在一个相同的正在运行的Activity,系统都会创建一个新的 Activity实例并显示出来。为了不让Activity实例化多次,我们需要通过在AndroidManifest.xml配置activity的加 载方式(launchMode)以实现单任务模式,如下所示:

 

<activity android:label="@string/app_name"android:launchmode="singleTask"android:name="Activity1"></activity>

 

launchMode 为singleTask的时候,通过Intent启到一个Activity,如果系统已经存在一个实例,系统就会将请求发送到这个实例上,但这个时候,系统就不会再调用通常情况下我们处理请求数据的onCreate方法,而是调用onNewIntent方法,如下所示:

 protected voidonNewIntent(Intent intent) {

 

   super.onNewIntent(intent);

 

  setIntent(intent);//must store the new intentunless getIntent() will return the old one

 

  processExtraData();

 

 }


不要忘记,系统可能会随时杀掉后台运行的Activity,如果这一切发生,那么系统就会调用onCreate方法,而不调用onNewIntent方法,一个好的解决方法就是在onCreate和onNewIntent方法中调用同一个处理数据的方法,如下所示:

 public voidonCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);setContentView(R.layout.main); processExtraData(); }protectedvoid onNewIntent(Intent intent) {super.onNewIntent(intent); setIntent(intent);//must store the new intent unless getIntent() will returnthe old one processExtraData() }privatevoid processExtraData(){ Intent intent =getIntent();//use the data received here }

二、onNewIntent()的setIntent()和getIntent()

@Override

protected void onNewIntent(Intent intent) {

        super.onNewIntent(intent);

 

        //setIntent(intent);

 

        int data =getIntent().getIntExtra("HAHA", 0);

        // int data= intent.getIntExtra("HAHA", 0);

}

如果没有调用setIntent(intent),则getIntent()获取的数据将不是你所期望的。但是使用intent.getInXxx,貌似可以获得正确的结果。

注意这句话:
Note thatgetIntent() still returns the original Intent. You can use setIntent(Intent) toupdate it to this new Intent.

所以最好是调用setIntent(intent),这样在使用getIntent()的时候就不会有问题了

 

 public voidonCreate(Bundle savedInstanceState) {

 

   super.onCreate(savedInstanceState);

 

   setContentView(R.layout.main);

 

  processExtraData();

 

 }

 

 protected voidonNewIntent(Intent intent) {

 

   super.onNewIntent(intent);

 

  setIntent(intent);//must store the new intentunless getIntent() will return the old one

 

  processExtraData()

 

 }

 

 private voidprocessExtraData(){

 

   Intent intent =getIntent();

 

   //use the data received here

 

 }

 

 二、onNewIntent()的setIntent()和getIntent()

 

@Override

protected void onNewIntent(Intent intent) {

        super.onNewIntent(intent);

 

        //setIntent(intent);

 

        int data =getIntent().getIntExtra("HAHA", 0);

        // int data= intent.getIntExtra("HAHA", 0);

}

 

 如果没有调用setIntent(intent),则getIntent()获取的数据将不是你所期望的。但是使用intent.getInXxx,貌似可以获得正确的结果。 

 注意这句话:

 Note that getIntent() still returns theoriginal Intent. You can use setIntent(Intent) to update it to this new Intent.

 

 所以最好是调用setIntent(intent),这样在使用getIntent()的时候就不会有问题了。



还有其他的人回答是:

前提:ActivityA已经启动过,处于当前应用的Activity堆栈中;

当ActivityA的LaunchMode为SingleTop时,如果ActivityA在栈顶,且现在要再启动ActivityA,这时会调用onNewIntent()方法

当ActivityA的LaunchMode为SingleInstance,SingleTask时,如果已经ActivityA已经在堆栈中,那么此时会调用onNewIntent()方法

 


0 0