废话
今天我们来学习Activity的生命周期
生命周期
- onCreate
从字面意思可以看出这个是Activity被创建时调用,在这里我们可以做一些初始化的工作,比如获取控件和绑定事件之类的。 - onStart
在onCreate调用结束后,就会调用onStart方法,表明Activity的初始化工作已经结束,准备将界面显示出来 - onResume
执行到onResume方法就表明Activity之前的准备工作已经做好,界面已经显示出来,用户可以与之进行交互 - onPause
当用户点击Back键或者Home键,以及启动一个新的活动,那么这个此方法就会执行 - onStop
同onPause一样,在启动一个新活动和按住Back或者Home时调用,那这个时候就会有个疑问,Activity有没有只执行到onPause的情况,有,当启动的新活动没有完全遮挡Activity的话,那么就Activity就只会执行到onPause方法,比如一个对话框 - onDestroy
此方法是当一个Activity销毁时执行的,表明这个Activity已经结束了自己的生命,这时系统就会来回收此Activity - onRestart
这个方法是在Activity从onStop状态回到onResume状态时调用的,顺序是onStart -> onRestart -> onResume,比如A Activity打开了B Activity,此时A处于onStop状态,B 进入onResume状态,然后关闭B,此时的A就会调用onRestart
体验Activity的生命周期
生命周期全过程
- 我们新建一个工程,并重写生命周期回调的所有方法,并加上日志打印
public class MainActivity extends AppCompatActivity {
private static final String TAG=MainActivity.class.getSimpleName();
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.i(TAG,"onCreate");
}
@Override
protected void onStart() {
super.onStart();
Log.i(TAG,"onStart");
}
@Override
protected void onResume() {
super.onResume();
Log.i(TAG,"onResume");
}
@Override
protected void onPause() {
super.onPause();
Log.i(TAG,"onPause");
}
@Override
protected void onStop() {
super.onStop();
Log.i(TAG,"onStop");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.i(TAG,"onDestroy");
}
@Override
protected void onRestart() {
super.onRestart();
Log.i(TAG,"onRestart");
}
}
接着,我们运行此项目到模拟器或者真机上,可以看到
12-22 13:05:28.115 16233-16233/? I/MainActivity: onCreate
12-22 13:05:28.116 16233-16233/? I/MainActivity: onStart
12-22 13:05:28.122 16233-16233/? I/MainActivity: onResume
然后,我们按Back键退出app,可以看到
12-22 13:05:28.115 16233-16233/? I/MainActivity: onCreate
12-22 13:05:28.116 16233-16233/? I/MainActivity: onStart
12-22 13:05:28.122 16233-16233/? I/MainActivity: onResume
12-22 13:06:42.258 16233-16233/? I/MainActivity: onPause
12-22 13:06:42.766 16233-16233/? I/MainActivity: onStop
12-22 13:06:42.767 16233-16233/? I/MainActivity: onDestroy
这就是Activity从创建到销毁的全过程
接着,我们重新打开app,然后点击home键,可以看到
12-22 13:08:31.933 16233-16233/? I/MainActivity: onCreate
12-22 13:08:31.935 16233-16233/? I/MainActivity: onStart
12-22 13:08:31.938 16233-16233/? I/MainActivity: onResume
12-22 13:08:43.880 16233-16233/? I/MainActivity: onPause
12-22 13:08:43.901 16233-16233/? I/MainActivity: onStop
Activity并没有执行onDestroy方法,所有Activity还没被销毁,这时我们再次点击app图标,进入app,可以看到
12-22 13:08:31.933 16233-16233/? I/MainActivity: onCreate
12-22 13:08:31.935 16233-16233/? I/MainActivity: onStart
12-22 13:08:31.938 16233-16233/? I/MainActivity: onResume
12-22 13:08:43.880 16233-16233/? I/MainActivity: onPause
12-22 13:08:43.901 16233-16233/? I/MainActivity: onStop
12-22 13:09:55.310 16233-16233/? I/MainActivity: onRestart
12-22 13:09:55.315 16233-16233/? I/MainActivity: onStart
12-22 13:09:55.319 16233-16233/? I/MainActivity: onResume
这时onRestart方法得到执行,表示Activity重新启动了
Activity被完全遮挡
我们看下Activity被完全遮挡的情况,这个完全遮挡就是启动了一个新的Activity(其实点击home进入桌面也可以看成是启动了桌面app)
我们新建一个Activity,记得要在AndroidManifest.xml文件中注册
SecondActivity.java*
public class SecondActivity extends AppCompatActivity{
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);
}
}
activity_second.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:text="Second Activity"
android:textColor="#000000"
android:textSize="18sp"/>
</LinearLayout>
AndroidManifest.xml
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.yk.activitydemo">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme" >
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".SecondActivity"/>
</application>
</manifest>
接下来修改下MainActivity.java和activity_main.xml
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/main_btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Start SecondActivity"/>
</LinearLayout>
MainActivity.java
public class MainActivity extends AppCompatActivity {
private static final String TAG=MainActivity.class.getSimpleName();
private Button mBtn;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.i(TAG,"onCreate");
mBtn=(Button)findViewById(R.id.main_btn);
mBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent=new Intent(MainActivity.this,SecondActivity.class);
startActivity(intent);
}
});
}
...
}
运行一下app,并点击一下Button,可以看到已经跳转到SecondActivity,这时,观察日志
12-22 13:24:41.364 21567-21567/com.yk.activitydemo I/MainActivity: onCreate
12-22 13:24:41.366 21567-21567/com.yk.activitydemo I/MainActivity: onStart
12-22 13:24:41.371 21567-21567/com.yk.activitydemo I/MainActivity: onResume
12-22 13:24:43.745 21567-21567/com.yk.activitydemo I/MainActivity: onPause
12-22 13:24:44.108 21567-21567/com.yk.activitydemo I/MainActivity: onStop
然后我们点击back键,回到MainActivity
12-22 13:24:41.364 21567-21567/com.yk.activitydemo I/MainActivity: onCreate
12-22 13:24:41.366 21567-21567/com.yk.activitydemo I/MainActivity: onStart
12-22 13:24:41.371 21567-21567/com.yk.activitydemo I/MainActivity: onResume
12-22 13:24:43.745 21567-21567/com.yk.activitydemo I/MainActivity: onPause
12-22 13:24:44.108 21567-21567/com.yk.activitydemo I/MainActivity: onStop
12-22 13:25:30.625 21567-21567/com.yk.activitydemo I/MainActivity: onRestart
12-22 13:25:30.626 21567-21567/com.yk.activitydemo I/MainActivity: onStart
12-22 13:25:30.628 21567-21567/com.yk.activitydemo I/MainActivity: onResume
可以看到MainActivity执行了onRestart方法,和点击home键的效果是一样的
Activity被部分遮挡
我们来修改SecondActivity的样式,把它变成一个对话框Activity
AndroidManifest.xml
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.yk.activitydemo">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme" >
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".SecondActivity"
android:theme="@style/Theme.AppCompat.Dialog"/>
</application>
</manifest>
重新运行,并点击Button,可以看到日志:
12-22 13:34:02.243 25151-25151/com.yk.activitydemo I/MainActivity: onCreate
12-22 13:34:02.246 25151-25151/com.yk.activitydemo I/MainActivity: onStart
12-22 13:34:02.251 25151-25151/com.yk.activitydemo I/MainActivity: onResume
12-22 13:34:04.375 25151-25151/com.yk.activitydemo I/MainActivity: onPause
总结
这样我们就把Activity的生命周期体验了一遍,当然,Activity还有很多种情况,后面我们会一一补充。