1.Android系统中Activity作为Activity栈(Stack)被管理的,大家都知道栈的特点是先进后出,所以当前活动的Activity处于栈顶,之前非活动的Activity被压入栈底,等待是否可能被恢复为活动状态。
Android API中所提供的Activity生命周期图:
2.下面的整个Activity生命周期中的所有方法,我们可以根据程序的需要来覆盖相应的方法:
- public class Activity extends ApplicationContext {
-
-
protected void onCreate(Bundle savedInstanceState);
-
-
protected void onStart();
-
-
protected void onRestart();
-
-
protected void onResume();
-
-
protected void onPause();
-
-
protected void onStop();
-
-
protected void onDestroy();
- }
onCreate(Bundle savedInstanceState):创建activity时调用。设置在该方法中,还以Bundle的形式提供对以前储存的任何状态的访问!
onStart():activity变为在屏幕上对用户可见时调用。
onResume():activity开始与用户交互时调用(无论是启动还是重新启动一个活动,该方法总是被调用的)
onPause():activity被暂停或收回cpu和其他资源时调用,该方法用于保存活动状态的,也是保护现场,压栈。
onStop():activity被停止并转为不可见阶段及后续的生命周期事件时调用。
onRestart():重新启动activity时调用。该活动仍在栈中,而不是启动新的活动
onDestroy():activity被完全从系统内存中移除时调用
3.下面通过实例来测试Activity的生命周期中各个方法的调用情况,将Activity的所有方法都覆盖,主要用Log打印输出信息,并通过日志(LogCat)方式来观察运行结果。Log.v(String tag, String msg); //Verbose
Log.d(String tag, String msg); //Debug
Log.i(String tag, String msg); //Info
Log.w(String tag, String msg); //Warning
Log.e(String tag, String msg); //Error
tag类似标签,可以是任意字符串,通常可以使用类名+方法名, 主要是用来在查看日志时提供一个筛选条件。
下面的实例是测试Activity的生命周期中各个方法的调用情况:
MainActivity.java
- package com.android.TestAvtivity.activity;
-
-
import android.app.Activity;
-
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 btn;
-
private static final String TAG="MainActivity";
-
@Override
-
public void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
-
-
Log.i(TAG, "MainActivity onCreate--->");
- btn = (Button)findViewById(R.id.Button1);
-
btn.setOnClickListener(new OnClickListener() {
-
@Override
-
public void onClick(View v) {
-
-
MainActivity.this.finish();
- }
- });
- }
-
-
@Override
-
-
protected void onStart() {
-
super.onStart();
-
-
Log.i(TAG, "MainActivity onStart--->");
- }
-
-
@Override
-
-
protected void onRestart() {
-
super.onRestart();
-
-
Log.i(TAG, "MainActivity onRestart--->");
- }
-
-
@Override
-
-
protected void onResume() {
-
super.onResume();
-
-
Log.i(TAG, "MainActivity onResume--->");
- }
-
-
@Override
-
-
protected void onPause() {
-
super.onPause();
-
-
Log.i(TAG, "MainActivity onPause--->");
- }
-
-
@Override
-
-
protected void onStop() {
-
super.onStop();
-
-
Log.i(TAG, "MainActivity onStop--->");
- }
-
-
@Override
-
-
protected void onDestroy() {
-
super.onDestroy();
-
-
Log.i(TAG, "MainActivity onDestroy--->");
- }
- }
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="fill_parent"
-
android:layout_height="fill_parent"
-
>
-
<TextView
-
android:id="@+id/TextView01"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:text="测试Activit生命周期"
-
/>
-
<Button
-
android:id="@+id/Button1"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:text="关闭Activity"
-
/>
-
</LinearLayout>
效果图:
①当启动程序时,日志的输出结果如下图所示,程序执行了onCreate()->onStart()->onResume三个方法。输出如下:
MainActivity onCreate--->
MainActivity onStart--->
MainActivity onResume--->
注意:这里我是在选择了绿色的“+”,这时出现了下图的界面,之后我就在Filter Name上写入Test,by Log Tag上写入MainActivity,按OK保存,这时就能在LogCat上面筛选我们想要看到的信息了。
②当按(返回键)或者按钮时,日志的输出结果如下图所示,程序先后调用了onPause( )->onStop( )->onDestory( )三个方法。
③当按(Home键)时,日志的输出结果如下图所示,程序先后调用了onPause( )->onStop( )这两个方法,这时候应用程序并没有销毁。
④当再次启动程序时,日志的输出结果如下图所示,程序先后调用了onRestart( )->onStart( )->onResume( )三个方法。
本文转自 lingdududu 51CTO博客,原文链接:
http://blog.51cto.com/liangruijun/636913