Activity启动及匹配

Activity生命周期

onStart/onResume这两个配对方法是从Activity是否可见的角度来回调的。
onResume/onPause是从Activity是否位于前台这个角度来回调的。
onCreate/onDestroy标志Activity的创建和销毁,并且只可能有一次调用。

启动Activity涉及的流程

启动Activity的请求会由Instrumentation处理。
Instrumentation通过Binder向AMS发送请求。
AMS内部维护着一个ActivityStack,并负责栈内的Activity的状态同步。
AMS通过ActivityThread去同步Activity的状态而完成生命周期方法的调用。

注意事项:
不能在onPause中进行重量级操作的原因:
必须当前页面执行完onPause操作,新Activity才能Resume.

异常情况处理

默认情况,当系统配置发生变化(横竖屏切换等),Activity会被销毁重建。系统会默认保存当前Activity的视图结构(EditText输入数据,ListView滚动位置等),原因是每个View都有对应的onSaveInstanceState/onRestoreInstanceState方法。

onSaveInstanceState调用时机:
只有Activity被异常终止的情况下才会回调(比如横竖屏切换),调用时机在onStop之前,和onPause没有既定的时序关系。有机会看源码
onRestoreInstanceState的调用时机在onStart之后。一旦被调用,其参数Bundle savedInstanceState一定是有值的。

内存不足情况处理

当系统内存不足时,按照以下优先级杀死目标Activity所在进程:

  1. 前台Activity
  2. 可见但非前台Activity
  3. 后台Activity

启动模式

  • standard 标准模式
    创建的activity实例运行在启动它的那个activity所在的任务栈中。
    非Activit类型的Context(如ApplicationContext)没有Activity所属的任务栈。当为待启动的Activity制定FLAG_ACTIVITY_NEW_TASK标记位时,实际上以singleTask模式创建了一个新的任务栈去启动。

  • singleTop 栈顶复用模式
    位于栈顶的Activity不会重建,同时它的onNewIntent方法会被回调。

  • singleTask 栈内复用模式
    当Activity A以singleTsk模式启动,系统会先寻找是否存在A想要的任务栈。
    如果不存在,就重新创建一个任务栈并将创建的A实例放入栈中。
    如果存在A所需的任务栈,则看栈中有无该实例。
    如果栈中无实例则创建A实例并压入栈中。
    如果栈中有实例,则clearTop将实例以上的Activity全部出栈,并调用此时在栈顶的onNewIntent方法。
    可通过taskaffinity指定所需任务栈

  • singleInstance
    具有singleTask所有特性,此模式的Activity只能单独位于一个任务栈中。
    任务栈分为前台任务栈和后台任务栈,后台任务栈中的activity位于暂停状态,用户可以通过切换将后台任务栈再次调回前台。

IntentFilter匹配规则

只有Intent同时匹配action/category/data才算完全匹配。

  • action匹配
    要求intent及IntentFilter中都有action的存在。
    且intent中的action必须和过滤额规则中的其中一个action相同。

  • category匹配
    要求Intent中如果含有category,那么所有的category都必须和过滤规则中的某个category相同。
    系统在startActivity(ForResult)时会默认为Intent加上"android.intent.category.DEFAULT"这个category。
    IntentFilter中如果不包含上"android.intent.category.DEFAULT"这个category,则无法接收到隐式Intent。

  • data匹配
    如果过略规则中定义了data,那么Intent中必须也要定义可匹配的data。
    data由两部分组成,mimeType和URI。mimeType指媒体类型,不如image/jpeg、video/*等,可表示图片、文本、视频等不同的媒体格式。
    URI默认值为content和file。

过滤规则中action为MAIN且category为LAUNCHER共同用于标明这是个入口Activity且会出现在系统的应用列表中。

Android API level及Android version一览

  • API 26 (Android 8.0) – Oreo, released August 2017.
  • API 25 (Android 7.1) – Nougat, released December 2016.
  • API 24 (Android 7.0) – Nougat, released August 2016.
  • API 23 (Android 6.0) – Marshmallow, released August 2015.
  • API 22 (Android 5.1) – Lollipop, released March 2015.
  • API 21 (Android 5.0) – Lollipop, released November 2014.
  • API 20 (Android 4.4W) – Kitkat Watch, released June 2014.
  • API 19 (Android 4.4) – Kitkat, released October 2013.
  • API 18 (Android 4.3) – Jelly Bean, released July 2013.
  • API 17 (Android 4.2-4.2.2) – Jelly Bean, released November 2012.
  • API 16 (Android 4.1-4.1.1) – Jelly Bean, released June 2012.
  • API 15 (Android 4.0.3-4.0.4) – Ice Cream Sandwich, released December 2011.
  • API 14 (Android 4.0-4.0.2) – Ice Cream Sandwich, released October 2011.
  • API 13 (Android 3.2) – Honeycomb, released June 2011.
  • API 12 (Android 3.1.x) – Honeycomb, released May 2011.
  • API 11 (Android 3.0.x) – Honeycomb, released February 2011.
  • API 10 (Android 2.3.3-2.3.4) – Gingerbread, released February 2011.
  • API 9 (Android 2.3-2.3.2) – Gingerbread, released November 2010.
  • API 8 (Android 2.2.x) – Froyo, released June 2010.
  • API 7 (Android 2.1.x) – Eclair, released January 2010.
  • API 6 (Android 2.0.1) – Eclair, released December 2009.
  • API 5 (Android 2.0) – Eclair, released November 2009.
  • API 4 (Android 1.6) – Donut, released September 2009.
  • API 3 (Android 1.5) – Cupcake, released May 2009.
  • API 2 (Android 1.1) – Base, released February 2009.
  • API 1 (Android 1.0) – Base, released October 2008.

你可能感兴趣的:(Activity启动及匹配)