Android查缺补漏--Activity生命周期和启动模式

一、生命周期

  • onCreate():启动Activity时,首次创建Activity时回调。
  • onRestart():再次启动Activity时回调。
  • onStart():首次启动Activity时在onCreate()之后被回调,再次启动时在onRestart()之后被回调。此时Activity已经可见但还没出现到前台不能与用户交互。
  • onResume():在onStart()之后被回调,此时Activity已经完全可见并且可以与用户交互。
  • onPause():当用户返回或者跳转到下一个Activity时会回调此方法,表示正在停止当前Activity,但此时Activity依然可见,通常紧接着会回调onStop()。
  • onStop():表示Activity即将停止。
  • onDestroy():表示Activity被销毁。

值得注意的地方:

  1. onStart和onResume咋看起来差不多,但有一些细微的差别,onStart表示Activity虽然此时已经可见但并没有完全显示到前台,onResume表示此时已经完全显示到前台了,并可以与用户交互了,onPause和onStop区别类似于此。
  2. 当ActivityA启动ActivityB时,他们的生命周期方法执行顺序如下:
    A.onPause->B.onCreate->B.onStart->B.onResume->A.onStop

日志如下:

12-05 17:18:24.666 778-778/cn.codingblock.androidadvancestudy I/MainActivity: onPause: 
12-05 17:18:24.674 778-778/cn.codingblock.androidadvancestudy I/BActivity: onCreate: 
12-05 17:18:24.687 778-778/cn.codingblock.androidadvancestudy I/BActivity: onStart: 
12-05 17:18:24.688 778-778/cn.codingblock.androidadvancestudy I/BActivity: onResume: 
12-05 17:18:25.006 778-778/cn.codingblock.androidadvancestudy I/MainActivity: onStop: 

1、普通情况下的Activity生命周期方法执行顺序:

  • 启动一个Activity:onCreate()->onStart()->onResume();
  • 当在当前Activity中跳转到下一个页面时(或者被用户切换到后台时),当前的Activity会被暂停:onPause()->onStop();
  • 然后再返回这个Activity时:onRestart()->onStart()->onResume();
  • Activity退出时:onPause()->onStop()->onDestroy()。

2、横竖屏切换时Activity生命周期方法执行顺序:

  • onPause()->onSaveInstanceState()->onStop()->onDestroy()->onCreate()->onStart()->onRestoreInstanceState()->onResume()。

在横竖屏切换时Activity会先被销毁,然后再重新创建,在销毁时onPause()被调用之后会调用onSaveInstanceState(Bundle bundle),此时我们就有机会将一些需要恢复的信息写入onSaveInstanceState()的Bundle参数中,在Activity被重建时,调用onStart()之后会调用onRestoreInstanceState(Bundle bundle),此时我们就可以在onRestoreInstanceState()用来恢复一些必要的信息,而它的参数就是我们在onSaveInstanceState写入的参数。

3、系统内存不足导致低优先级的Activity被回收时的生命周期方法执行顺序

此种情况和第二种横竖屏切换时的情况查不多,也会执行onSaveInstanceState()和onRestoreInstanceState()。

二、四种启动模式

  • standard:默认的启动方式,Activity可以被多次实例化,即同一个栈中可以存在多个Activity实例。

如果用ApplicationContext去启动standard模式的Activity的时候会报错,这是因为此模式的Activity默认会进入启动它的Activity所属的任务栈中,而非Activity类型的Context并有没有任务栈。解决办法就是在用ApplicationContext启动Activity时指定FLAG_ACTIVITY_NEW_TASK即可,这样在启动Activity时就会为它创建一个新栈。

  • singleTop:栈顶复用模式。以singleTop模式启动的Activity如果已经有一个示例存在栈顶,那么再启动这个Activity时就会重用这个示例,并调用onNewIntent()方法。如果不在栈顶,则会创建新的示例,效果如standard一致。

  • singleTask:栈内复用模式。此模式只允许一个栈中只存在一个该Activity的实例,启动此模式的Activity时,如果栈中没有该Activity的实例,则会创建新的实例。如果栈中已经存在该实例了,系统会销毁在其之上的所有Activity,最终让该Activity实例置于栈顶,并回调onNewIntent()方法。

  • singleInstance:单实例模式。该模式的Activity只在一个独立的任务栈中开启,并且这个新的任务栈中有且只有这一个实例。当再次启动该Activity实例时,会重用已存在的任务和实例(并调用onNewIntent)。而该Activity启动的其他Activity会自动运行与另一个任务栈中。

singleInstance和singleTask的区别:

  • singleInstance在同一个时刻,在系统中只会存在一个实例,而singleTask模式的Activity可以有多个实例,只要这些实例在不同的任务栈中即可。
  • 比如应用A启动了一个singleInstance的Activity,而应用B也启动了这个Activity,那么会重用已经启动的实例。

最后想说的是,本系列文章为博主对Android知识进行再次梳理,查缺补漏的学习过程,一方面是对自己遗忘的东西加以复习重新掌握,另一方面相信在重新学习的过程中定会有巨大的新收获,如果你也有跟我同样的想法,不妨关注我一起学习,互相探讨,共同进步!

参考文献:

  • 《Android开发艺术探索》
  • 《Android开发进阶从小工到专家》
posted @ 2017-12-24 21:25  codingblock  阅读(292)  评论(1编辑  收藏  举报