本文转载。时间久远,找不到原创作者链接!
状态转化:
-
activity在onPause重获焦点后转到可见状态onResume.
-
activity在onStop状态时,若用户重新进入activity,activity进入onRestart状态。
-
activity在onStop状态时,若系统内存不足,会kill掉该activity所在的app,若用户进入该activity,则activity进入onCreate状态。
-
到达oncreate:app被kill掉|app被destroy,用户进入app。
可见性:
1.activity有焦点,处于onResume与onPause之间
2.activity处于前台可见状态:在onRestart与onStop之间。
3.activity的活跃时间:在onCreate与onDestroy之间。
4.activity的创建与销毁时间分别在onCreate与onDestroy状态。
Activity的生命周期:所谓的典型的生命周期就是在有用户参与的情况下,Activity经历从创建,运行,停止,销毁等正常的生命周期过程。我们这里先来介绍一下几个主要方法的调用时机,然后再通过代码层面来验证其调用流程。
onCreate :该方法是在Activity被创建时回调,它是生命周期第一个调用的方法,我们在创建Activity时一般都需要重写该方法,然后在该方法中做一些初始化的操作,如通过setContentView设置界面布局的资源,初始化所需要的组件信息等。
onStart :此方法被回调时表示Activity正在启动,此时Activity已处于可见状态,只是还没有在前台显示,因此无法与用户进行交互。可以简单理解为Activity已显示而我们无法看见摆了。
onResume :当此方法回调时,则说明Activity已在前台可见,可与用户交互了(处于前面所说的Active/Running形态),onResume方法与onStart的相同点是两者都表示Activity可见,只不过onStart回调时Activity还是后台无法与用户交互,而onResume则已显示在前台,可与用户交互。当然从流程图,我们也可以看出当Activity停止后(onPause方法和onStop方法被调用),重新回到前台时也会调用onResume方法,因此我们也可以在onResume方法中初始化一些资源,比如重新初始化在onPause或者onStop方法中释放的资源。
onPause :此方法被回调时则表示Activity正在停止(Paused形态),一般情况下onStop方法会紧接着被回调。但通过流程图我们还可以看到一种情况是onPause方法执行后直接执行了onResume方法,这属于比较极端的现象了,这可能是用户操作使当前Activity退居后台后又迅速地再回到到当前的Activity,此时onResume方法就会被回调。当然,在onPause方法中我们可以做一些数据存储或者动画停止或者资源回收的操作,但是不能太耗时,因为这可能会影响到新的Activity的显示——onPause方法执行完成后,新Activity的onResume方法才会被执行。
onStop :一般在onPause方法执行完成直接执行,表示Activity即将停止或者完全被覆盖(Stopped形态),此时Activity不可见,仅在后台运行。同样地,在onStop方法可以做一些资源释放的操作(不能太耗时)。
onRestart:表示Activity正在重新启动,当Activity由不可见变为可见状态时,该方法被回调。这种情况一般是用户打开了一个新的Activity时,当前的Activity就会被暂停(onPause和onStop被执行了),接着又回到当前Activity页面时,onRestart方法就会被回调。
onDestroy:此时Activity正在被销毁,也是生命周期最后一个执行的方法,一般我们可以在此方法中做一些回收工作和最终的资源释放。
创建--->启动---->显示(前台可见)--->暂停--->停止(Activity不可见,仅在后台运行)---->销毁。
本文详细介绍了Android中Activity的生命周期,包括从创建到销毁的过程及各生命周期回调方法的作用。重点讲解了onCreate、onStart、onResume等关键方法的触发条件,并解释了不同状态之间的转换。
2074

被折叠的 条评论
为什么被折叠?



