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所在进程:
- 前台Activity
- 可见但非前台Activity
- 后台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.