Android 关于Activity的生命周期

Android 关于Activity的生命周期_第1张图片
以梦为马,越骑越傻。诗和远方,越远越脏.jpg

作为Android四大组件之一的Activity,熟练掌握Activity的生命周期应该是每一个Android开发者都应该知道的事情。下面我们就生命周期中的方法调用顺序聊聊。

先看一张整体生命周期的流程图

Android 关于Activity的生命周期_第2张图片
Activity生命周期.png

从上面的图片中我们可以看到,一个Activity从诞生到死亡一共经历了6个阶段,一般来说我们在代码中会重写onCreate()方法与onDestroy()方法。我们很少去重其他四个方法,但是既然是生命周期的方法那一定会有它存在的道理。

下面我们说说每一个生命周期的方法都有什么作用。

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

作为Activity启动时执行的第一个方法,它的主要任务是

  • 绑定视图(Layout)并且进行绘制
  • 将数据跟View进行绑定
  • 加载一些开发者在这个Activity用到的组件

onCreate方法在整个Activity的生命周期中之后调用一次,就是在创建这个Activity的时候去执行。这个时候用户是看不见界面的,也就是说这个Activity还是不可见的状态。如果我们在onCreate()方法中执行了耗时操作,这样的会导致用户使用时有卡顿的状态,影响用户体验。所以在onCreate()方法我们尽可能的不进行耗时操作。

    @Override
    protected void onStart() {
        super.onStart();
    }

执行onStart方法的时候onCreate方法已经走完了,界面的绘制也完成了,这个时候用户是可以看到界面的,但是不能获取焦点进行交互。

    @Override
    protected void onResume() {
        super.onResume();
    }

执行onResume方法时,用户可以获取焦点,进行交互,执行完onResume后整个Activity就处于可用的状态了。

    @Override
    protected void onPause() {
        super.onPause();
    }

比如说我们要跳转到其他的页面,这个时候当前的Activity先执行onPause方法,让当前的Activity失去焦点,不能进行交互,但是用户界面是可见的。

    @Override
    protected void onStop() {
        super.onStop();
    }

在onPause方法执行过后会执行onStop方法,这个时候这个Activity处于暂停的转台并且不在前台展示了,但是还没有被销毁。

    @Override
    protected void onDestroy() {
        super.onDestroy();
    }

执行onDestroy方法时我们会对这个Activity进行销毁,在销毁之前JVM的GC机制会对内存进行回收,在这个过程中,如果我们在其他地方存在对该Activity的强引用,则会导致内存泄露。这样就不会执行onDestroy方法了。
通常我们会在onDestroy方法对该Activity中绑定的Service、BroadcastReceiver、eventBus、观察者、还有一些类似ButterKnife等需要我们在onCreate方法中去绑定的,在onDestroy的时候我们都要进行解绑操作。
当我们调用finish()方法的时候我们会发现并不会立即执行onDestroy的方法。执行finish()方法的时候我们是将这个Activity从栈中移除了,但是资源还没有被释放,当资源释放之后就会调用onDestroy方法了。

    @Override
    protected void onRestart() {
        super.onRestart();
    }

onRestart方法在生命周期中是不一定会调用到的方法,常用的地方为当用户从A->B,再从B返回A的时候A就会调用onRestart方法,在onRestart方法中我们可以做一些事情,比如B的操作可能会引起A数据的变化,那么我们可以在调用onRestart方法的时候去请求数据。

在从A跳转到B的时候各个Activity的生命周期调用的顺序

A  Activity
    @Override
    protected void onPause() {
        super.onPause();
    }
B  Activity
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }
    @Override
    protected void onStart() {
        super.onStart();
    }
    @Override
    protected void onResume() {
        super.onResume();
    }
A  Activity
    @Override
    protected void onStop() {
        super.onStop();
    }

从B返回到A是各个Activity生命周期执行的顺序

B  Activity
    @Override
    protected void onPause() {
        super.onPause();
    }
A  Activity
    @Override
    protected void onRestart() {
        super.onRestart();
    }
    @Override
    protected void onStart() {
        super.onStart();
    }
    @Override
    protected void onResume() {
        super.onResume();
    }
B  Activity
    @Override
    protected void onStop() {
        super.onStop();
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
    }

在横竖屏切换的时候Activity的生命周期变化

1.竖>>>>>横
onSaveInstanceState
onPause
onStop
onDestroy
onCreate
onStart
onRestoreInstanceState
onResume
2.横>>>>>竖
与竖屏切横屏执行的生命周期方法一样,只不过在横屏切换到竖屏的时候执行两次生命周期方法
3.设置Activity的android:configChanges="orientation"时,横竖屏的切换都只执行一次生命周期的方法
onSaveInstanceState
onPause
onStop
onDestroy
onCreate
onStart
onRestoreInstanceState
onResume
onConfigurationChanged
4.设置Activity的android:configChanges="orientation|keyboardHidden"时,横竖屏切换不会调用生命周期方法,只执行onConfigurationChanged方法。

Framgent的使用对Activity的生命周期是否有影响

在Activity中调用Fragment不会影响到Activity的生命周期,由于Fragment依附于Activity,所以Fragment的生命周期受到Activity的影响。并且Fragment的生命周期方法要比Activity多两个方法。具体是哪些方法下一篇再细说。

注:文中的图片出处http://blog.csdn.net/liuhe688/article/details/6733407

PS:小伙伴们的关注与点赞是对我最大的支持,请用的鼠标给我多一点支持吧。

你可能感兴趣的:(Android 关于Activity的生命周期)