覆盖的android生命周期方法如何在超级调用之后运行代码,而无需转到其后续的生命周期方法

时间:2018-09-26 17:42:48

标签: java android android-lifecycle super

看看这个。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
}

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

假定此代码来自Activity类的子级的正常活动。 super.onCreate()onCreate()中的第一条陈述。此超级调用必须是连接点,以通知父类在派生类中调用onCreate(),并且可以调用下一个生命周期方法,显然是onStart()

也就是说,执行顺序必须是这样的:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);              <-- ( 1 )
    setContentView(R.layout.activity_main);          <-- ( 3 )
}

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

但是看起来却是这样工作的:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);              <-- ( 1 )
    setContentView(R.layout.activity_main);          <-- ( 2 )
}

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

怎么可能?

1 个答案:

答案 0 :(得分:3)

因为onStart()是在之后 onCreate(),而不是来命名。

看看here

ActivityThread#startActivityNow()实例化活动并调用onCreate()

几行之内,您会看到对ActivityThread#handleStartActivity()的呼叫。{p}

由于那里没有异步,因此Java将等待onStart()完成,然后再继续调用onCreate()

检查source comments in Activity.java,以了解有关活动生命周期如何工作的更多详细信息。