一、什么是Activity?

简单的说:Activity或者悬浮于其它窗体上的交互界面。

在一个应用程序中通常由多个Activity构成。都会在Manifest.xml中指定一个主的Activity,例如以下设置

<actionandroid:name="android.intent.action.MAIN" />

当程序第一次执行时用户就会看这个Activity,这个Activity能够通过启动其它的Activity进行相关操作。当启动其它的Activity时这个当前的这个Activity将会停止,新的Activity将会压入栈中,同一时候获取用户焦点,这时就可在这个Activity上操作了。都知道栈是先进后出的原则,那么当用户按Back键时,当前的这个Activity销毁。前一个Activity又一次恢复。

二、Activity生命周期

先看下图:

这个图不再多说什么,以下我们通过一个实例来说明问题。

新建project,编写例如以下代码:

package com.android.ttx.actiitylifedemo;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.KeyEvent;
public class ActivityLifeDemo extends Activity {
private final static String TAG="ActivityLifeDemo"; @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); Log.i(TAG, "onCreate");
}
@Override
protected void onStart() {
Log.i(TAG, "onStart");
super.onStart();
}
@Override
protected void onRestart() {
Log.i(TAG, "onRestart");
super.onRestart();
}
@Override
protected void onResume() {
Log.i(TAG, "onResume");
super.onResume();
}
@Override
protected void onPause() {
Log.i(TAG, "onPause");
super.onPause();
}
@Override
protected void onStop() {
Log.i(TAG, "onStop");
super.onStop();
}
@Override
protected void onDestroy() {
Log.i(TAG, "onDestroy");
super.onDestroy();
}
}

代码非常easy,仅仅涉及到一个Activity,一些用户的操作,我们通过记录操作和打印日志的方式来看看Activity的生命周期过程。

1、  执行

看到例如以下打印日志:

08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onCreate

08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onStart

08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onResume

2、按下返回按键:

08-31 09:29:57.396: INFO/ActivityLifeDemo(354): onPause

08-31 09:29:58.216: INFO/ActivityLifeDemo(354): onStop

08-31 09:29:58.216: INFO/ActivityLifeDemo(354): onDestroy

3、长按Home键。弹出近期打开过的应用程序,点击ActivityLifeDemo

08-31 08:51:46.916: INFO/ActivityLifeDemo(312): onCreate

08-31 08:51:46.916: INFO/ActivityLifeDemo(312): onStart

08-31 08:51:46.936: INFO/ActivityLifeDemo(312): onResume

4、按Home键

08-31 08:53:32.676: INFO/ActivityLifeDemo(312): onPause

08-31 08:53:33.796: INFO/ActivityLifeDemo(312): onStop

5、在AllList中点击打开

08-31 08:54:14.286: INFO/ActivityLifeDemo(312): onRestart

08-31 08:54:14.286: INFO/ActivityLifeDemo(312): onStart

08-31 08:54:14.296: INFO/ActivityLifeDemo(312): onResume

通过日志信息。我们能够看到。Activity的启动过程:onCreate—onStart—onResume;下返回键时:onPause—onStop—onDestroy 正如上面说是,当按下返回键时,此Activity弹出栈。程序销毁。确实如此。我们再次 打开时的启动过程又回到onCreate—onStart—onResume。OK,启动之后按下Home键。回到Launcher。查看信息打印:onPause—onStop。再次打开的执行过程:onRestart—onStart—onResume。

我们通过对Activity的各种操作,构成了Activity的生命周期,我们看到不管对Activity做怎样的操作,都会接收到相关的回调方法,那么我们在开发的过程中通过这些回调方法就能够写工作,比方说释放一些重量级的对象。网络连接,数据库连接,文件读等等。

下面是各个方法的具体说明:

onCreate():当 activity 第一次创建时会被调用。

在这种方法中你须要完毕全部的正常静态设置 ,比方创建一个视图( view )、绑定列表的数据等等。

假设能捕获到 activity 状态的话,这种方法传递进来的 Bundle 对象将存放了 activity 当前的状态。

调用该方法后通常会调用 onStart() 方法。

onRestart():在 activity 被停止后又一次启动时会调用该方法。其兴许会调用 onStart 方法。

onStart()à当 activity 对于用户可见前即调用这种方法。假设 activity回到前台则接着调用 onResume() 。假设 activity 隐藏则调用onStop()

onResume():在 activity 開始与用户交互前调用该方法。在这时该activity 处于 activity 栈的顶部,而且接受用户的输入。

其兴许会调用 onPause() 方法。

onPause():在系统准备開始恢复其他 activity 时会调用该方法。

这种方法中通经常使用来提交一些还没保存的更改到持久数据 中。停止一些动画或其他一些耗 CPU 的操作等等。不管在该方法里面进行不论什么操作。都须要较高速完毕,由于假设它不返回的话,下一个 activity 将无法恢复出来。

假设 activity 返回到前台将会调用 onResume() ,假设 activity 变得对用户不可见了将会调用onStop() 。

onStop():在 activity 对用户不可见时将调用该方法。可能会由于当前 activity 正在被销毁。或还有一个 activity (已经存在的activity 或新的 activity )已经恢复了正准备覆盖它,而调用该方法。假设 activity 正准备返回与用户交互时兴许会调用onRestart ,假设 activity 正在被释放则会调用 onDestroy 。

onDestroy():在 activity 被销毁前会调用该方法。

这是 activity 能接收到的最后一个调用。可能会由于有人调用了 finish 方法使得当前activity 正在关闭,或系统为了保护内存暂时释放这个 activity的实例,而调用该方法。你能够用 isFinishing 方法来区分这两种不同的情况。

三、怎样启动一个新的Activity?

要启动一个新的Activity。我们能够通过调用Context中的startActivity来启动。像这样:

Intent intent = new Intent(this, ActivityDemo.class);
startActivity(intent); // ActivityDemo是须要启动的Activity类

通过上面的方法能够启动新的Activity了,但假设我要从当前的Activity中传递数据到新的Activity呢?非常easy:

Intent intent = new Intent(this,ActivityDemo.class);
Bundle bundle = new Bundle();
bundle.putBoolean("bool_key", true);
intent.putExtras(bundle);
startActivity(intent);

还有,有时候我们须要启动带返回值的Activity。简单的说就是须要新启动的Activity返回时将值传递给启动它的Activity。像这样:

Intent intent = new Intent(ActivityLifeDemo.this,RevalueActivity.class);
startActivityForResult(intent, 0x1001);

ActivityLifeDemo是当前的Activity。启动RevalueActivity,我们在ActivityLifeDemo中须要获取RevalueActivity传回来的值。

那么在RevalueActivity中就必须这样写:

Intent intent  = new Intent();
intent.putExtra("revalue_key","haha-revalueActivity");
setResult(0x1001, intent);

那么“revalue_key”值在哪里获取呢?必须重写onActivityResult方法。通过推断requestCode,来确定

if(requestCode==0x1001){
String str = data.getStringExtra("revalue_key");
Log.i(TAG, "返回的值为:"+str);
}

好了。具体的请看代码吧。下载地址:http://download.csdn.net/detail/tangcheng_ok/3580700

四、保存Activity执行状态

通过重写onSaveInstanceState()方法来实现Activity的执行状态。请注意下面几点:

1)因为activity 对象被暂停或停止时,它仍然保留在内存里面,关于它的成员信息和当前状态都是活动的,所以此时能够保存Activity的状态,从而使用户所作的Activity的更改保存在内存中

2)  当系统回收内存而将Activity销毁时,就无法保存其状态,所以须要调用onSaveInstanceState()方法来实现状态的保存

3)  非常多情况并不须要保持状态信息,比方按下返回键直接关闭程序。所以并不能保证会调用onSaveInstanceState。假设调用了该方法。通常是在onStop 方法之前且可能在 onPause 之后调用。虽然如此,即使你没做不论什么操作或没有实现 onSaveInstanceState() 方法,你的 activity 状态也能通过Activity 类里面默认实现的 onSaveInstanceState 方法恢复出来。

特别是会为布局中的视图( View )默认调用onSaveInstanceState 方法。并在这种方法中同意每个视图提供它须要恢复的不论什么信息。差点儿每个 Android框架中的 widget 都视情况实现了这种方法。

注:由于 onSaveInstanceState 方法不一定会被调用。所以你应该仅仅是用它来保存一些 activity 的转换过程状态(即 UI 的状态),而不能用来保存永久性数据。但你能够用 onPause 方法在用户离开 activity 时来保存永久性数据。比方须要保存到数据库的数据。

有一个非常好的方法能够用来检验应用程序保存状态的能力。就是简单地旋转你的设备来改变屏幕的方向。由于当屏幕方向改变时,系统为了给新的方向提供一个可能合适的取代资源,会销毁 activity 并新建一个新的。

由于这个原因,你的 activity 能否在其又一次创建时完毕保存状态就显得尤为重要,由于用户常常会在使用应用程序时旋转屏幕的。

上文部分内容參考了:http://blog.csdn.net/sam_zhang1984/article/details/6430817,在这里多谢这位博主了。

五、全然退出程序

通过上面的介绍,我们知道当点击back键时。程序调用了onDestroy方法。程序退出了,可是我们查看其进程,发现调用了onDestroy方法之后这个Activity还在执行。

甚至调用了finish()方法之后程序还能在进程中看到。通过以下这样的方式能够实现程序的全然退出:

Intent intent = new Intent();
Intent.setClass(context,MainActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
intent.putExtra(“flag”,EXIT_APPLICATION);
context.startActivity(intnet);

ok。到目前为止。

这篇文章的制备。


Activity详细解释(生命周期、以各种方式启动Activity、状态保存,等完全退出)的更多相关文章

  1. Android Small插件化框架解读——Activity注册和生命周期

    通过对嵌入式企鹅圈原创团队成员degao之前发表的<Android Small插件化框架源码分析>的学习,对Android使用的插件化技术有了初步的了解,但还是有很多需要认真学习的地方,特 ...

  2. Activity完整的生命周期

    首语:群里看到一位网友说:你能说出Activity的完整生命周期吗?看到这句话,我也在反思自己,我也是个fresh,所以想找个时间仔细的扒一扒Activity生命周期. 首先拿一张简单而又复杂的生命周 ...

  3. 无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)

    1.activity的生命周期 这七个方法定义了Activity的完整生命周期.实现这些方法可以帮助我们监视其中的三个嵌套生命周期循环: (1)Activity的完整生命周期 自第一次调用onCrea ...

  4. 多个Activity交互的生命周期:

    一.多个Activity交互的生命周期: A Activity打开B Activity的时候:        A Activity                    B Activity     ...

  5. 三张图让你高速明确activity与fragment生命周期的异同点

    第一张图:activity的生命周期 第二张图:fragment的生命周期 第三张图:activity与fragment生命周期对照 补充:假设你还是不明确,请翻译一下你不理解的相应单词. ----- ...

  6. (转)iOS应用程序生命周期(前后台切换,应用的各种状态)详解

    原文:http://blog.csdn.net/totogo2010/article/details/8048652 iOS应用程序生命周期(前后台切换,应用的各种状态)详解         分类:  ...

  7. 转:iOS应用程序生命周期(前后台切换,应用的各种状态)详解

    iOS应用程序生命周期(前后台切换,应用的各种状态)详解 分类: iOS开发进阶2012-10-08 15:35 42691人阅读 评论(30) 收藏 举报 iosapplication任务anima ...

  8. Activity具体解释(生命周期、以各种方式启动Activity、状态保存,全然退出等)

    一.什么是Activity? 简单的说:Activity就是布满整个窗体或者悬浮于其它窗体上的交互界面.在一个应用程序中通常由多个Activity构成,都会在Manifest.xml中指定一个主的Ac ...

  9. Activity具体解释(生命周期、启动方式、状态保存,全然退出等)

    一.什么是Activity? 简单的说:Activity就是布满整个窗体或者悬浮于其它窗体上的交互界面. 在一个应用程序中通常由多个Activity构成,都会在Manifest.xml中指定一个主的A ...

随机推荐

  1. VI01增强问题

    函数'SD_SCD_ITEM_PRICING_DATA_GET',其实在增强中和交货相关的数据在这个函数中都可以取到,没有必要再从LIKP.LIPS等等中重新取数. include程序RV64A631 ...

  2. TPL异步并行编程之取消任务

    TPL异步并行编程之简单使用 在上篇随笔里面说明了Task的使用,仅仅是简单使用,有时候把一个任务交给Task去执行,但是呢还是要管理下,比如说:我要叫这个任务停止了,不做了,任务取消了,或者超时了 ...

  3. 使用Elasticsearch、Logstash、Kibana与Redis(作为缓冲区)对Nginx日志进行收集(转)

    摘要 使用Elasticsearch.Logstash.Kibana与Redis(作为缓冲区)对Nginx日志进行收集 版本 elasticsearch版本: elasticsearch-2.2.0 ...

  4. ANDROID 中设计模式的採用--创建型模式

     所谓模式就是在某一情景下解决某个问题的固定解决方式. 全部的创建型模式都是用作对象的创建或实例化的解决方式. 1 简单工厂模式 创建对象的最简单方法是使用new来创建一个对象,假设仅仅创建一种固 ...

  5. SRM 624 Building Heights DivI 解读

    几乎相同的一标题.欲了解更多请参阅:http://community.topcoder.com/stat?c=problem_statement&pm=13211&rd=15857 思 ...

  6. 条款38 通过复合塑膜出has-a或&quot;依据某物实现&quot;

    结论: 复合的意义和public继承全然不同. (public继承參考:条款32 确定你的public继承塑模出is-a关系) 在应用域,复合意味着has-a(有一个).在实现域,复合意味着is-im ...

  7. 与众不同 windows phone (22) - Device(设备)之摄像头(硬件快门, 自动对焦, 实时修改捕获视频)

    原文:与众不同 windows phone (22) - Device(设备)之摄像头(硬件快门, 自动对焦, 实时修改捕获视频) [索引页][源码下载] 与众不同 windows phone (22 ...

  8. html中的rowspan和colspan

    摘自w3school(http://www.w3school.com.cn/tags/att_td_colspan.asp)colspan 属性规定单元格可横跨的列数.<table border ...

  9. php 如何在有限的内存中读取大文件

    突然遇到了一个要读取超过80M文件的需求,很悲剧的,不管是file_get_content还是file什么的,都会将读取的文件一次性加载到内存中. 正常情况下,我们可以使用fseek来读取,好处就是不 ...

  10. flex网上办(苹果)桌面系统仿真

    1.有登录界面 2.能够载入app(每一个app是单独的swf),并可拖动app的图标互相叠加 3.桌面上显示的哪些APP与目录是依据登陆的用户信息.从webservice中读取的(名字.图标信息等) ...