首先看一下Android api中所提供的Activity生命周期图

Activity其实是继承了ApplicationContext这个类,我们可以重写以下方法,如下代码:

  1. public class Activity extends ApplicationContext {
  2. protected void onCreate(Bundle savedInstanceState);
  3. protected void onStart();
  4. protected void onRestart();
  5. protected void onResume();
  6. protected void onPause();
  7. protected void onStop();
  8. protected void onDestroy();
  9. }

便于大家更好的理解,我简单的写了一个Demo,不明白Activity周期的朋友们,可以亲手实践一下,大家按照我的步骤来。

第一步:新建一个Android工程,我这里命名为ActivityDemo.

第二步:修改ActivityDemo.Java(我这里重新写了以上的七种方法,主要用Log打印),代码如下:

  1. package com.tutor.activitydemo;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.util.Log;
  5. public class ActivityDemo extends Activity {
  6. private static final String TAG = "ActivityDemo";
  7. public void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.main);
  10. Log.e(TAG, "start onCreate~~~");
  11. }
  12. @Override
  13. protected void onStart() {
  14. super.onStart();
  15. Log.e(TAG, "start onStart~~~");
  16. }
  17. @Override
  18. protected void onRestart() {
  19. super.onRestart();
  20. Log.e(TAG, "start onRestart~~~");
  21. }
  22. @Override
  23. protected void onResume() {
  24. super.onResume();
  25. Log.e(TAG, "start onResume~~~");
  26. }
  27. @Override
  28. protected void onPause() {
  29. super.onPause();
  30. Log.e(TAG, "start onPause~~~");
  31. }
  32. @Override
  33. protected void onStop() {
  34. super.onStop();
  35. Log.e(TAG, "start onStop~~~");
  36. }
  37. @Override
  38. protected void onDestroy() {
  39. super.onDestroy();
  40. Log.e(TAG, "start onDestroy~~~");
  41. }
  42. }

第三步:运行上述工程,效果图如下(没什么特别的):

核心在Logcat视窗里,如果你还不会用Logcat你可以看一下我的这篇文章Log图文详解我们打开应用时先后执行了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),代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <TextView
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:text="@string/hello"
  11. />
  12. <EditText
  13. android:id="@+id/editText"
  14. android:layout_width="fill_parent"
  15. android:layout_height="wrap_content"
  16. />
  17. </LinearLayout>

第五步:然后其他不变,运行ActivityDemo程序,在EditText里输入如"Frankie"字符串(如下图:)

这时候,可以按一下HOME键,然后再次启动ActivityDemo应用程序,这时候EditText里并没有我们输入的"Frankie"字样,如下图:

这显然不能称得一个合格的应用程序,所以我们需要在Activity几个方法里自己实现,如下第六步所示:

第六步修改ActivityDemo.java代码如下:

  1. package com.tutor.activitydemo;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.util.Log;
  5. import android.widget.EditText;
  6. public class ActivityDemo extends Activity {
  7. private static final String TAG = "ActivityDemo";
  8. private EditText mEditText;
  9. //定义一个String 类型用来存取我们EditText输入的值
  10. private String mString;
  11. public void onCreate(Bundle savedInstanceState) {
  12. super.onCreate(savedInstanceState);
  13. setContentView(R.layout.main);
  14. mEditText = (EditText)findViewById(R.id.editText);
  15. Log.e(TAG, "start onCreate~~~");
  16. }
  17. @Override
  18. protected void onStart() {
  19. super.onStart();
  20. Log.e(TAG, "start onStart~~~");
  21. }
  22. //当按HOME键时,然后再次启动应用时,我们要恢复先前状态
  23. @Override
  24. protected void onRestart() {
  25. super.onRestart();
  26. mEditText.setText(mString);
  27. Log.e(TAG, "start onRestart~~~");
  28. }
  29. @Override
  30. protected void onResume() {
  31. super.onResume();
  32. Log.e(TAG, "start onResume~~~");
  33. }
  34. //当我们按HOME键时,我在onPause方法里,将输入的值赋给mString
  35. @Override
  36. protected void onPause() {
  37. super.onPause();
  38. mString = mEditText.getText().toString();
  39. Log.e(TAG, "start onPause~~~");
  40. }
  41. @Override
  42. protected void onStop() {
  43. super.onStop();
  44. Log.e(TAG, "start onStop~~~");
  45. }
  46. @Override
  47. protected void onDestroy() {
  48. super.onDestroy();
  49. Log.e(TAG, "start onDestroy~~~");
  50. }
  51. }

第七步:重新运行ActivityDemo程序,重复第五步操作,当我们按HOME键时,再次启动应用程序时,EditText里有上次输入的"Frankie"字样,如下图如示:

Activity生命周期图的更多相关文章

  1. Activity状态图、生命周期图(超详细),onSaveInstanceState只保存、恢复基本ui数据,持久数据不在这里保存。

    1.Activity状态图 2.Activity生命周期简图 启动Activity: onCreate()—>onStart()—>onResume(),Activity进入running ...

  2. Android: 实例解析Activity生命周期

    Activity生命周期图: 下面以一个实例来解析,实例APP运行,进入MainActivity, 点击Send Button以后进入MessgaeActivity 当第一次运行App,进入MainA ...

  3. [转]: 两分钟彻底让你明白Android Activity生命周期(图文)!

    转自:http://blog.csdn.net/android_tutor/article/details/5772285 大家好,今天给大家详解一下Android中Activity的生命周期,我在前 ...

  4. Android Activity生命周期

    从android api文档摘抄出来的activity生命周期图如下: Activity有如下四种状态 a.活动状态  activity处于屏幕前台,获取到了焦点可以和用户进行交互,同一时刻只有一个a ...

  5. 两分钟彻底让你明白Android Activity生命周期(图文)!

    大家好,今天给大家详解一下Android中Activity的生命周期,我在前面也曾经讲过这方面的内容,但是像网上大多数文章一样,基本都是翻译Android API,过于笼统,相信大家看了,会有一点点的 ...

  6. Android Activity生命周期以及Fragment生命周期的区别与分析

    Android Fragment生命周期图: Activity生命周期图: 对照图: Fragment生命周期分析: 1. 当一个fragment被创建的时候,它会经历以下状态. onAttach() ...

  7. (转)两分钟彻底让你明白Android Activity生命周期(图文)!

    转自: http://blog.csdn.net/android_tutor/article/details/5772285 大家好,今天给大家详解一下Android中Activity的生命周期,我在 ...

  8. onAttachedToWindow()在整个Activity生命周期的位置及使用

    onAttachedToWindow在整个Activity的生命周期中占据什么位置? 为什么要在onAttachedToWindow中修改窗口尺寸? 一.onAttachedToWindow在Acti ...

  9. Android Activity 生命周期详解

    学习android开发这么久对于activity的生命周期还没有仔细思考过,所以,我大致的把这些东西整理一下,希望通过这使自己理解的更透彻点吧! 首先看一下Activity生命周期图和它的的四个阶段 ...

随机推荐

  1. ssh框架整合完整版

    1.导入jar包 可以在src下添加一个log4j.properties文件来记录日志 2.加入实体类+映射文件 映射:从类入手class+属性 a.映射的头文件在:hibernate3.jar--& ...

  2. ASP.Net 5 上传文件通过虚拟路径存储

    先贴上代码 [HttpPost] public IActionResult ImportTeaching(IFormFile file) { string root = @"Temp/tea ...

  3. css 伪类::after ::beftor 的使用方式

    注释:对于 IE8 及更早版本中的 :before,必须声明 . ::before和::after这两个主要用来给元素的前面或后面插入内容,这两个常用"content"配合使用,见 ...

  4. linux服务器部署svn常见错误处理→转载

    转载地址→http://blog.seweal.com/post/2013-02-04/svn-errors [开放svn端口] iptables -I INPUT -p tcp --dport 36 ...

  5. FineUI第六天---表单控件

    表单控件 所有表单控件都有的属性有: ShowLabel:是否显示标签(默认值:true). ShowEmptyLabel:是否显示空白的标签(默认值:false). Label:标签文本(默认值:& ...

  6. [Effective JavaScript 笔记]第32条:始终不要修改__proto__属性

    __proto__属性很特殊,它提供了Object.getPrototypeOf方法所不具备的额外能力,即修改对象原型链接的能力. 避免修改__proto__属性的最明显的原因是可移植性的问题.并不是 ...

  7. UIWebView

    本地html string文件 loadHTMLString: 本地/远程文件 loadRequest

  8. 安装cuda时 提示toolkit installation failed using unsupported compiler解决方法

    在安装cuda的时候,有时候会提示toolkit installation failed using unsupported compiler.这是因为GCC版本不合适所导致的. 解决的方法很简单,直 ...

  9. HDU 1203 I NEED A OFFER (01背包&&概率dp)

    M - I NEED A OFFER! Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u ...

  10. css整个页面离顶部的距离

    body { padding:0; margin:0; font-size:12px; line-height:22px; } 说明: 整个页面离顶部的距离是22像素