您的位置:首页 > 移动开发 > Android开发

Android学习之核心组件Activity的生命周期

2015-12-17 20:54 627 查看
Activity是Android的核心组件,绝大多数的内置组件都依附于Activity之上。Activity有四种运行状态:

1.运行:此时Activity位于堆栈的顶部

2.暂停:Activity失去了焦点,但是依然可见。

3.停止:Activity完全被其他Activity所覆盖。

4.销毁:处于暂停或者停止状态下,因垃圾回收机制或者内存不足原因,结束生命。

在Android系统中,没有类似于C/Java之类的程序的main()方法入口。但是定义了Activity的一系列的生命周期方法。

从Activity的整个生命周期的顺序执行顺序来看,其从创建到销总共有如下的生命周期方法:

1.onCreate()-->2.onStart()--->3.onResume()--->4.onPause()--->5.onStop()--->6.onDestroy()

一个完整的Activity被调用后,其以上的六个生命周期方法都会被执行。C/Java代码一般从main()函数看是分析,Android程序一定要从MainActivity开始分析。

以下为Activity的生命周期函数的转换图。



这个流程图来自Android说明文档,下面简要说一说这几个过程。

1.启动Activity:系统会先调用onCreate方法,然后调用onStart方法,最后调用onResume,Activity进入运行状态。

2.当前Activity被其他Activity覆盖其上或被锁屏:系统会调用onPause方法,暂停当前Activity的执行。

3.当前Activity由被覆盖状态回到前台或解锁屏:系统会调用onResume方法,再次进入运行状态。

4.当前Activity转到新的Activity界面或按Home键回到主屏,自身退居后台:系统会先调用onPause方法,然后调用onStop方法,进入停滞状态。

5.用户后退回到此Activity:系统会先调用onRestart方法,然后调用onStart方法,最后调用onResume方法,再次进入运行状态。

6.当前Activity处于被覆盖状态或者后台不可见状态,即第2步和第4步,系统内存不足,杀死当前Activity,而后用户退回当前Activity:再次调用onCreate方法、onStart方法、onResume方法,进入运行状态。

7.用户退出当前Activity:系统先调用onPause方法,然后调用onStop方法,最后调用onDestory方法,结束当前Activity。

Activity的可视阶段为从onStart()--->onStop().

以下用一个例子来简要说明这些过程。

创建一个Android工程,在MainActivity.java中加入如下代码。

package com.example.mainactivitylife;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class MainActivity extends Activity {
private static final String TAG="lifecycle";
private static final String TBG="life";

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);   //加载用户界面
Log.i(TAG,"onCreate");        //打印日志lifecycle    onCreate
String content = getResources().getString(R.string.lifecicle);       //通过资源文件来得到String资源
String[] indexs = getResources().getStringArray(R.array.array_contents);  //通过资源文件来得到String-array资源
Log.i(TBG, content+indexs[0]);  //打印日志life    lifecycle:onCreate
}

@Override
protected void onStart(){
super.onStart();
Log.i(TAG, "onStart");   //打印日志lifecycle    onStart
String content = getResources().getString(R.string.lifecicle);   //通过资源文件来得到String资源
String[] indexs = getResources().getStringArray(R.array.array_contents);   //通过资源文件来得到String-array资源
Log.i(TBG, content+indexs[1]);   //打印日志life    lifecycle:onStart
}

@Override
protected void onResume(){
super.onResume();
Log.i(TAG, "onResume");
String content = getResources().getString(R.string.lifecicle);
String[] indexs = getResources().getStringArray(R.array.array_contents);
Log.i(TBG, content+indexs[2]);
}

@Override
protected void onPause(){
super.onPause();
Log.i(TAG, "onPause");
String content = getResources().getString(R.string.lifecicle);
String[] indexs = getResources().getStringArray(R.array.array_contents);
Log.i(TBG, content+indexs[3]);
}

@Override
protected void onStop(){
super.onStop();
Log.i(TAG, "onStop");
String content = getResources().getString(R.string.lifecicle);
String[] indexs = getResources().getStringArray(R.array.array_contents);
Log.i(TBG, content+indexs[4]);
}

@Override
protected void onDestroy(){
super.onDestroy();
Log.i(TAG, "onDestroy");
String content = getResources().getString(R.string.lifecicle);
String[] indexs = getResources().getStringArray(R.array.array_contents);
Log.i(TBG, content+indexs[5]);
}

}
string.xml文件配置

<?xml version="1.0" encoding="utf-8"?>
<resources>

<string name="app_name">MainActivityLife</string>
<string name="hello_world">Hello world!</string>
<string name="action_settings">Settings</string>
<string name="lifecicle">lifecycle:</string>

</resources>
array.xml文件 配置

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="array_contents">
<item>onCreate</item>
<item>onStart</item>
<item>onResume</item>
<item>onPause</item>
<item>onStop</item>
<item>onDestroy</item>
</string-array>
</resources>
运行后,打印日志如图:



图2为加入了从资源文件获得String和String-array后得到的日志。



从图中清楚了反映了Activity的生命周期。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: