http://jbg168.blog.163.com/blog/static/996836201072604651584/?fromdm&isFromSearchEngine=yes
首先看一下
Android api
中所提供的
Activity
生命周期图
(
不明白的,可以看完整篇文章,在回头看一下这个图,你会明白的
):
Activity其实是继承了ApplicationContext这个类,我们可以重写以下方法,如下代码:
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();
}
为了便于大家更好的理解,我简单的写了一个Demo,不明白Activity周期的朋友们,可以亲手实践一下,大家按照我的步骤来。
第一步:新建一个Android工程,我这里命名为ActivityDemo.
第二步:修改ActivityDemo.java(我这里重新写了以上的七种方法,主要用Log打印),代码如下:
package com.tutor.activitydemo;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
public class ActivityDemo extends Activity {
private static final String TAG = "ActivityDemo";
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Log.e(TAG, "start onCreate~~~");
}
@Override
protected void onStart() {
super.onStart();
Log.e(TAG, "start onStart~~~");
}
@Override
protected void onRestart() {
super.onRestart();
Log.e(TAG, "start onRestart~~~");
}
@Override
protected void onResume() {
super.onResume();
Log.e(TAG, "start onResume~~~");
}
@Override
protected void onPause() {
super.onPause();
Log.e(TAG, "start onPause~~~");
}
@Override
protected void onStop() {
super.onStop();
Log.e(TAG, "start onStop~~~");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.e(TAG, "start onDestroy~~~");
}
}
第三步:运行上述工程,效果图如下(没什么特别的):
核心在Logcat视窗里,如果你还不会用Logcat你可以看一下我的这篇文章
Log图文详解(Log.v,Log.d,Log.i,Log.w,Log.e)
,我们打开应用时先后执行了onCreate()->onStart()->onResume三个方法,看一下LogCat视窗如下:
BACK键:
当我们按BACK键时,我们这个应用程序将结束,这时候我们将先后调用onPause()->onStop()->onDestory()三个方法,如下图所示:
HOME键:
当我们打开应用程序时,比如浏览器,我正在浏览NBA新闻,看到一半时,我突然想听歌,这时
候我们会选择按HOME键,然后去打开音乐应用程序,而当我们按HOME的时候,Activity先后执行了
onPause()->onStop()这两个方法,这时候应用程序并没有销毁。如下图所示:
而当我们再次启动ActivityDemo应用程序时,则先后分别执行了onRestart()->onStart()->onResume()三个方法,如下图所示:
这里我们会引出一个问题,当我们按HOME键,然后再进入ActivityDemo应用时,我们的应用的状态应该是和按HOME键之前的状态是一样的,同样为了方便理解,在这里我将ActivityDemo的代码作一些修改,就是增加一个EditText。
第四步:修改main.xml布局文件(增加了一个EditText),代码如下:
<?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:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello"
/>
<EditText
android:id="@+id/editText"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
/>
</LinearLayout>
第五步:然后其他不变,运行ActivityDemo程序,在EditText里输入如"Frankie"字符串(如下图:)
这时候,大家可以按一下HOME键,然后再次启动ActivityDemo应用程序,这时候EditText里并没有我们输入的"Frankie"字样,如下图:
这显然不能称得一个合格的应用程序,所以我们需要在Activity几个方法里自己实现,如下第六步所示:
第六步修改ActivityDemo.java代码如下:
package com.tutor.activitydemo;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.EditText;
public class ActivityDemo extends Activity {
private static final String TAG = "ActivityDemo";
private EditText mEditText;
//定义一个String 类型用来存取我们EditText输入的值
private String mString;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mEditText = (EditText)findViewById(R.id.editText);
Log.e(TAG, "start onCreate~~~");
}
@Override
protected void onStart() {
super.onStart();
Log.e(TAG, "start onStart~~~");
}
//当按HOME键时,然后再次启动应用时,我们要恢复先前状态
@Override
protected void onRestart() {
super.onRestart();
mEditText.setText(mString);
Log.e(TAG, "start onRestart~~~");
}
@Override
protected void onResume() {
super.onResume();
Log.e(TAG, "start onResume~~~");
}
//当我们按HOME键时,我在onPause方法里,将输入的值赋给mString
@Override
protected void onPause() {
super.onPause();
mString = mEditText.getText().toString();
Log.e(TAG, "start onPause~~~");
}
@Override
protected void onStop() {
super.onStop();
Log.e(TAG, "start onStop~~~");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.e(TAG, "start onDestroy~~~");
}
}
第七步:重新运行ActivityDemo程序,重复第五步操作,当我们按HOME键时,再次启动应用程序时,EditText里有上次输入的"Frankie"字样,如下图如示:
OK,
大功基本告成,这时候大家可以在回上面看一下
Activity
生命周期图,我想大家应该完全了解了
Activity
的生命周期了
.
分享到:
相关推荐
两分钟彻底让你明白Android Activity生命周期(图文)
这是Activity生命周期中的活动状态。 4. **onPause()**:当Activity被部分或完全覆盖,但仍可见(例如弹出一个透明对话框)时调用。在此阶段,应保存临时数据,但不应进行耗时操作,因为这会影响用户体验。 5. **...
总之,深入理解Activity生命周期和其背后的源码逻辑,对于编写高效、响应迅速且用户体验优秀的Android应用至关重要。开发者应熟练掌握这些知识点,以便在设计和调试应用时能得心应手。通过实践和分析ActivityDemo,...
这是Activity生命周期中的活动状态。 4. **onPause()**:当Activity失去焦点但仍然部分可见(例如,弹出一个透明或半透明的对话框)时调用。在这个阶段,你应该保存非持久性数据并停止耗时操作。 5. **onStop()**...
### Android Activity 生命周期详解 #### 一、概述 在Android开发中,`Activity`是四大组件之一,用于构建用户界面,并负责与用户的交互。一个`Activity`通常对应着一个屏幕,当用户在一个应用的不同屏幕间导航时...
本文将通过图文详解的方式带你深入理解Android开发环境的基本构成,并对关键概念如Activity、配置文件、布局文件、常用控件以及Intent进行详细介绍。 首先,我们来认识一下Android。Android是一种基于Linux内核的...
两分钟彻底让你明白Android Activity生命周期(图文)! Android 图形系统剖析 Android 立体效果图片 NDK动态库的调用 Android 姿态传感器 Android 很酷的图像旋转 Android 添加音频 在Android中实现多线程断点下载 ...
在`AsyncTask`的生命周期结束时,记得取消网络请求和释放相关资源,同时在`Activity`或`Fragment`的生命周期方法中解除对`Handler`的引用。 以上就是实现“Android下从网络获取数据并实现图文混排效果”的关键知识...
在Android应用开发中,服务(Service)是一种用于执行长时间运行操作的组件,它不与用户界面...记得在完成测试后,根据应用需求选择合适的服务类型,是启动服务还是绑定服务,以及如何正确地管理和控制服务的生命周期。
8. **生命周期管理**:每个Activity都有自己的生命周期,开发者需要理解并适当地处理onCreate(), onStart(), onResume(), onPause(), onStop() 和 onDestroy()等方法。 9. **异常处理**:良好的错误处理机制是任何...
正确理解并运用这些启动模式,可以帮助开发者控制Activity的生命周期和任务管理,从而优化应用的导航流程和用户体验。例如,对于需要始终在顶层显示或者需要独立任务的Activity,可以选择singleTop或singleInstance...
最后,持续学习Android开发的基础知识,如四大组件(Activity、Service、BroadcastReceiver、ContentProvider)、生命周期、数据存储、网络请求、权限管理等。这将帮助你构建更复杂的应用。 通过以上步骤,你已经...
- 考虑到隐私和安全,正确处理文件的生命周期,分享完成后记得清理临时文件。 - 在使用`FileProvider`时,要遵循其规则,比如在提供URI时使用`getUriForFile()`方法。 通过以上步骤,你可以在Android应用中实现...
2.5 activity的生命周期 2.5.1 activity状态 2.5.2 剖析activity 2.6 android进程和线程 2.6.1 进程 2.6.2 线程 2.6.3 远程调用(remote procedure calls) 2.7 intent消息传递 2.8 intent广播事件 2.8.1 广播事件 ...
Fragment是一个可以嵌入到Activity中的UI片段,它有自己的生命周期和输入事件处理。Fragment的设计初衷是为了让开发者能够更好地管理和设计平板电脑或大屏幕设备上的多屏界面,但它们同样适用于手机应用,可以帮助...