一个Activity从被创建到被销毁都有一定的过程,这样的过程我们称之为Activity的生命周期。
对于Activity的生命周期,有这样一个图来描述它:
相信很多人都看到过这张图。
从这张图中我们可以看到,Activity的生命周期中存在7个状态:
onCreate(); Activity被创建
onStart(); Activity被开始运行
onResume(); Activity正在运行
onPause(); Activity被暂停
onStop(); Activity被停止
onRestart(); Activity被重新开始运行
onDestroy(); Activity被销毁
我们来走一下这样一个流程(其实上面的英文就已经描述的很清楚了):当运行程序后,Activity会依次执行这样3个状态:onCreate()、onStart()、onResume();在绿色框中就可以看到Activity is running,说明此时Activity正在运行当中。然后我们可以看到onResume()的下一个状态是onPause(),根据Another activity comes in front of the activity描述所说,就是当前Activity被其他的Activity覆盖了,那么就会执行onPause()这样一个状态。然后如果要回到onResume()状态,The activity comes to the foreground,Activity重新可见时执行。然后我们看到onPause()状态的左分支中,Other application need memory,其他应用程序需要内存时,Process is killed,该进程被杀死,直到用户再次使用时,重新创建。如果该Avtivity长时间处于onPause()状态时,执行到onStop()状态,即停止该Activity,同样,该状态时如果其他应用程序需要内存,则同样结束该进程。还有就是,如果要使该Activity重新显示,则需要调用onRestart(),重新开始运行该Activity。最后一个状态就是onDestroy()状态,这个就是销毁Activity的。
下面,通过一个实例来说明一下。并且通过Logcat来跟踪一下。
实例内容就是通过一个Activity 的intent跳转到另一个Activity。
package com.example.logcattest;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
public class MainActivity extends Activity {
private Button button1;
private String TAG = "ActivityTest";
/*
* 创建Activity
* */
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.d(TAG, "onCreate");
button1 = (Button) findViewById(R.id.button1);
button1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent();
intent.setClassName("com.example.logcattest", "com.example.logcattest.Activity01");
startActivity(intent);
}
});
}
/*
* 开始执行Activity
* */
@Override
protected void onStart() {
super.onStart();
Log.d(TAG, "onStart");
}
/*
* Activity正在运行(当前Activity可见,并且没有被其他Activity遮挡)
* */
@Override
protected void onResume() {
super.onResume();
Log.d(TAG, "onResume");
}
/*
* Activity暂停
* */
@Override
protected void onPause() {
super.onPause();
Log.d(TAG, "onPause");
}
/*
* Activity停止
* */
@Override
protected void onStop() {
super.onStop();
Log.d(TAG, "onStop");
}
/*
* Activity重新被执行
* */
@Override
protected void onRestart() {
super.onRestart();
Log.d(TAG, "onRestart");
}
/*
* Activity被销毁
* */
@Override
protected void onDestroy() {
super.onDestroy();
Log.d(TAG, "onDeatroy");
}
}
上面代码中,对于7个状态,用Logcat来打印他们的状态信息。
其他代码就不贴上去了,应该都懂的。
OK,现在把程序部署到模拟器上去,如下图:
然后我们可以通过Logcat窗口看到它里面的信息:
依次调用了onCreate()、onStart()、onResume();
当我们点击里面的按钮(跳转)时:
然后通过Logcat窗口可以看到:
依次调用了onPause()、onStop();
然后点击返回键,让它返回到主Activity时:
依次调用了onRestart()、onStart()、onResume();
当关闭程序时:
依次调用onPause()、onStop()、onDestroy();
这样,一个Activity从被创建到被销毁的流程就结束了。
OK,现在再来写一下关于横竖屏切换的Activity生命周期。
我们不可能只满足于竖屏的方式,有些游戏,横屏,那才玩的爽。。。
由于在模拟器上我没法做到让它横竖屏切来切去,我就直接说了把。
我们先来看一下这段代码:
/*
* 横竖屏切换时执行
* */
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
Log.d(TAG, "ConfigurationChanged");
}
上面那段代码,是当横竖屏切换时进行执行的。通过logcat进行标记。也就说当我横竖屏切换时,就会打印出ConfigurationChanged这段信息。
关于生命周期:当横竖屏切换时,会怎么样呢?销毁当前Activity,并且重新创建Activity。也就是说,当我要重竖屏切换到横屏时,会自动将当前竖屏的Activity给销毁,并且重新创建出横屏的Activity。但是这样一直销毁创建销毁创建往往满足不了我们的需求。我们需要的是,在进行横竖屏切换时,不销毁当前的Activity。
那么,怎么做呢?
我们需要在AndroidManifest.xml文件配置一下当前Activity的一个属性。代码如下:
android:configChanges="keyboardHidden|orientation|screenSize"
这样,就在横竖屏切换时不会销毁当前的Activity了。
那么,如果我们要使得当前要固定一个横屏或者竖屏,不能被切换该怎么做呢?这里就有两个属性可以决定:
android:screenOrientation="landscape" //横屏模式
android:screenOrientation="portrait" //竖屏模式
只要设置了这样其中一个属性,就不会再进行横竖屏切换了。
关于Activity的生命周期就先写到这儿了。还需要很多东西要学,不能操之过急了。
THE END~