什么是Activity生命周期
Activity即活动,生命周期则是开始到结束的各个状态。所以Activity生命周期即为安卓活动中的各个状态。
正常的生命周期
Activity7大生命周期:
onCreate():
创建Activity,Activity生命周期的第一个方法,主要是加载一些初始数据。
onStart():
表示Activity正在启动,并且即将开始,Activity可见但不可以与用户交互。
onResume():
Activity已经创建完成,Activity可见也可以进行用户交互事件。
onPause():
与onResume配对,表示Activity正在暂停,一般做一些存储数据、停止动画的工作,但是不能太耗时。
onStop():
与onStart配对,表示Activity即将停止,可以做一些稍微重量级的回收工作,同样也不能太耗时(相对于onPause好一点)。
onRestart():
表示Activity正在重新启动。一般来说Activity从不可见重新变为可见的状态时onRestart就会被调用。
onDestory():
与onCreate配对,表示Activity即将被销毁,这是Activity生命周期的最后一个回调,做一些回收工作和最终的资源释放。
运行结果
测试代码如下:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.e("s","onCreate");
}
@Override
protected void onStart() {
super.onStart();
Log.e("s","onStart");
}
@Override
protected void onResume() {
super.onResume();
Log.e("s","onPause");
}
@Override
protected void onPause() {
super.onPause();
Log.e("s","onPause");
}
@Override
protected void onStop() {
super.onStop();
Log.e("s","onStop");
}
@Override
protected void onRestart() {
super.onRestart();
Log.e("s","onRestart");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.e("s","onDestroy");
}
直接运行,结果为:
06-04 03:22:52.061 9032-9032/com.example.myapplication E/s: onCreate
06-04 03:22:52.063 9032-9032/com.example.myapplication E/s: onStart
06-04 03:22:52.065 9032-9032/com.example.myapplication E/s: onPause
现在点击返回:
06-04 03:22:58.549 9032-9032/com.example.myapplication E/s: onPause
06-04 03:22:59.136 9032-9032/com.example.myapplication E/s: onStop
06-04 03:22:59.140 9032-9032/com.example.myapplication E/s: onDestroy
再点击app:
06-04 03:23:46.680 9032-9032/com.example.myapplication E/s: onCreate
06-04 03:23:46.685 9032-9032/com.example.myapplication E/s: onStart
06-04 03:23:46.717 9032-9032/com.example.myapplication E/s: onPause
再点击旋转手机:
06-04 03:24:22.870 9032-9032/com.example.myapplication E/s: onPause
06-04 03:24:22.900 9032-9032/com.example.myapplication E/s: onStop
06-04 03:24:22.901 9032-9032/com.example.myapplication E/s: onDestroy
06-04 03:24:23.175 9032-9032/com.example.myapplication E/s: onCreate
06-04 03:24:23.178 9032-9032/com.example.myapplication E/s: onStart
06-04 03:24:23.215 9032-9032/com.example.myapplication E/s: onPause