onCreate():表示Activity正在创建,可以做初始化操作,setContentView(),初始化Activity所需要的数据;
onRestart():表示重启启动(或者回到前台进程),当Activity从不可见状态有重新变成可见状态时,例如用户按下Home键or启动新Activity后回到这个Activity,onRestart()就会被调用;(onPause() - onStop() - onRestart() - onStart() - onResume()) ;
onStart():Activity正在被启动,此时Activity已经可见但未出现在前台,但是无法与用户交互;
onResume():Activity此时已经可见并开始活动,可与用户进行交互;
onPause():表示Activity正在退出,正常情况下onStop()会马上调用,特殊情况下,新Activity主题为透明主题时,不会立即调用onStop(),但是在onPause()避免处理比较耗时的操作,会影响到新Activity显示,只有在onPause()结束后新Activity的onResume()才会被执行;
onStop()表示Activity即将停止,可以处理稍微重量级的耗时操作;
onDestory():此时Activity正在被销毁,也是生命周期最后一个执行的方法,一般我们可以在此方法中做一些回收工作和最终的资源释放。
异常情况下的生命周期分析
1、资源相关的系统配置发生改变导致Activity被杀死并重新创建,比如设备在横竖屏切换,此时Activity的onPause() - onStop() - onDestory()均会被调用,同时还会执行onSaveInstanceState(),来保存当前Activity的相关状态;当系统重新启动这个Activity时就会调用onRestoreInstanceState()。PS:View中也有这两个方法,其分发机制与View时间分发机制类似
2、资源内存不足时导致低优先级的Activity进程被杀死 ,我们可通过在AndroidMenifest.xml中配置Activity的android:configchange属性来决定是否在资源配置发生改变时调用onSaveInstanceState()、onRestoreInstanceState()方法,而是调用ActivityonConfigurationChanged()方法。
Activity的启动模式
Android有四种启动模式:standard、singleInstance、singTask、singleTop
standard:标准模式,最常见的一种。注意的是:通过ApplicationContext启动Activity时需要注意的添加FlAG_ACTIVITY_NEW_TASK,此时待启动的Activity就是以singleTask模式启动;
singleTop: 栈顶复用模式,如果此时Activity位于栈顶,同时为SingleTop模式,那么Activity将不会被创建,但是onNewIntent()方法将会被调用
singleTask: 栈内复用模式,单例模式启动方式。与singleTop()启动方式类似,也会调用onNewIntent()方法。关于Activity退出应用时运用
singleInstance: 单实例模式,加强型的singleTask,当设置为singleInstance模式的Activity只能单独存在一个新的任务栈中,后续君不悔创建新的Activity,除非系统将此任务栈回收
另外:通过adb shell dumpsys activity来查看当前任务栈的相关信息
IntentFilter的匹配规则
一个Activity可以有多个<intent-filter>,一个Intent只要能够匹配其中的一组<intent-filter>就可以成功启动Activity。主要action、category、data信息
action匹配规则:只要Intent能够匹配<intent-filter>中的任何一个action即可,区分字母大小写,并且action必须存在;
category匹配规则:<intent-filter>中存在几个category,那么intent设置的每一个category都必须匹配<intent-filter>中的category;
data匹配规则:与action匹配规则类似,通过隐式调用Activity时,可以提前通过PackageManager的resloveActivity(Intent intent, int flag)返回匹配成功的Activity,提供程序的健壮性;也可通过PackageManager的queryIntentActivitis(Intent intent, int flag)返回所有符合<intent-filter>的Activity