这次开始玩玩活动的生命周期。废话不说,先搞个小应用,大体思路是:主界面有两个按钮,一个按钮按下后,出现第二个界面;另一个按钮按下后,出现第三个界面,真他妈简单。

一、主界面:

1. 主界面布局xml文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >

<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello" />

<Button
android:id="@+id/btnToSecond"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="callSecondActivity" />

<Button
android:id="@+id/btnToThird"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="callThirdActivity" />

</LinearLayout>

我的神~~~

2. 主界面逻辑代码:

package cn.com.sxp;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;

public class ActivityLifeActivity extends Activity {
private static final String TAG = ActivityLifeActivity.class
.getSimpleName();
private Button btnToSecond = null;
private Button btnToThird = null;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

Log.i(TAG, "ActivityLifeActivity onCreate()");

btnToSecond = (Button) this.findViewById(R.id.btnToSecond);
btnToSecond.setOnClickListener(new View.OnClickListener() {

@Override
public void onClick(View v) {
Intent intent = new Intent(ActivityLifeActivity.this,
secondActivity.class);
startActivity(intent);
}
});

btnToThird = (Button) this.findViewById(R.id.btnToThird);
btnToThird.setOnClickListener(new View.OnClickListener() {

@Override
public void onClick(View v) {
Intent intent = new Intent(ActivityLifeActivity.this,
thirdActivity.class);
startActivity(intent);
}
});
}

@Override
protected void onDestroy() {
Log.i(TAG, "ActivityLifeActivity onDestroy()");
super.onDestroy();
}

@Override
protected void onPause() {
Log.i(TAG, "ActivityLifeActivity onPause()");
super.onPause();
}

@Override
protected void onRestart() {
Log.i(TAG, "ActivityLifeActivity onRestart()");
super.onRestart();
}

@Override
protected void onResume() {
Log.i(TAG, "ActivityLifeActivity onResume()");
super.onResume();
}

@Override
protected void onStart() {
Log.i(TAG, "ActivityLifeActivity onStart()");
super.onStart();
}

@Override
protected void onStop() {
Log.i(TAG, "ActivityLifeActivity onStop()");
super.onStop();
}
}

漂亮:这样的话,搞出来的界面就是:

跑出来的日志:

可以看到,主界面活动经过了创建、开始、恢复三个状态。

二、第二个界面

1. 界面的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:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="欢迎来到第二个活动"
/>
</LinearLayout>

很简单,就一个文本框,说着一些废话。

2. 第二个见面的逻辑代码:

package cn.com.sxp;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import cn.com.sxp.R;

public class secondActivity extends Activity {
private static final String TAG = secondActivity.class.getSimpleName();
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.second);

Log.i(TAG, "secondActivity onCreate()");
}

@Override
protected void onDestroy() {
Log.i(TAG, "secondActivity onDestroy()");
super.onDestroy();
}

@Override
protected void onPause() {
Log.i(TAG, "secondActivity onPause()");
super.onPause();
}

@Override
protected void onRestart() {
Log.i(TAG, "secondActivity onRestart()");
super.onRestart();
}

@Override
protected void onResume() {
Log.i(TAG, "secondActivity onResume()");
super.onResume();
}

@Override
protected void onStart() {
Log.i(TAG, "secondActivity onStart()");
super.onStart();
}

@Override
protected void onStop() {
Log.i(TAG, "secondActivity onStop()");
super.onStop();
}
}

哇靠,日志打得真JB详细。

3. 看效果

此时,我在主界面按第一个按钮,效果图如下:

再来看日志:

瓦擦,谁能告诉我发生了什么!

主活动暂停了,不过此时你还能看到主界面,只是你不能与之交互了;第二个界面活动经历了创建、开始、恢复变得与客户可见,客户还能操作它;最后,主界面完全不可见了,不过并没有销毁。

好吧,我按下退后按钮,会发生什么?

I can not believe~~~

退回到主界面时,二界面先暂停,他不肯离去;主界面此时并未销毁,因此是重启状态,开始状态,恢复状态;二界面停止,并且销毁。在一个界面,按下退后键应该就是销毁这个活动吧。

从活动栈的角度来说,二界面出现时,主界面是在被入栈的,二界面此时在栈顶;主界面要想重新占据栈顶,必须把现有的栈顶的活动宰掉才行;宰掉就是销毁了。

三、主界面按下退后键呢?

主界面被宰了,被销毁了。

我按下“esc”键,主界面也是被销毁。

四、不不,我不按后退,我按home键

请看日志:


what happened~~~主界面活动没有被销毁,它只是stop~~~stop

当我在手机上重启启动这个主界面,回调的是restart(),Oh~~~what a kidding~~~

五、关于 onSaveInstanceState() 和 onRestoreInstanceState()两个方法呢?更值得研究一下

android_activity_研究(二)的更多相关文章

  1. Fiddler实战深入研究(二)

    Fiddler实战深入研究(二) 阅读目录 Fiddler不能捕获chrome的session的设置 理解数据包统计 请求重定向(AutoResponder) Composer选项卡 Filters选 ...

  2. (转载)Fiddler实战深入研究(二)

    原文来源于:http://www.cnblogs.com/tugenhua0707/p/4637771.html,作者:涂根华 !个人觉得文章写的特别好,故收藏于此,感谢原作者的分享 Fiddler实 ...

  3. Fiddler实战深入研究(二)[转载]

    Fiddler实战深入研究(二) 阅读目录 Fiddler不能捕获chrome的session的设置 理解数据包统计 请求重定向(AutoResponder) Composer选项卡 Filters选 ...

  4. Nginx源码研究二:NGINX的事件处理概论

    NGINX作为服务端的应用程序,在客户端发出数据后,服务端在做着这样一些处理,数据先会经过网卡,网卡会和操作系统做交互,经过操作系统的协议栈处理,再和不同的应用程序交互. 在这里面涉及两个概念,一个是 ...

  5. tomcat 组件研究二--请求过程

    上一篇博客大概总结了tomcat 的组件以及其组织方式,对于tomcat 的启动过程也进行进行了简单的总结,下面这篇博客,继续研究tomcat 处理请求的相关组件,其实就是主要研究Connectors ...

  6. [转] Java se 7新特性研究(二)

    详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp82   今天主要研究Java se 7中异常处理的新功能.从今天开始正在 ...

  7. android_activity_研究(一)

    android中活动的概念(activity)是一个很重要的东东.这里有很多东东值得好好研究.最好的研究来源当然是官网啦,所以本人这里写一点对官网文章的研究心得. 一.活动(activity)的概念 ...

  8. dedecms代码研究二

    dedecms代码研究(2)从index开始现在继续,今天讲的主要是dedecms的入口代码.先打开index.PHP看看里面是什么吧.打开根目录下的index.php嗯映入眼帘的是一个if语句.检查 ...

  9. 关于linux系统如何实现fork的研究(二)

    本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 引言 前一篇关于linux系统如何实现fork的研究(一)通过代码已经说明了从用户态怎么通过软中断实现调用系统调 ...

随机推荐

  1. 二叉树基本操作C代码

    #include<stdio.h> #include<malloc.h> #define LEN sizeof(struct ChainTree) struct ChainTr ...

  2. WebBrowser 的 DocumentCompleted事件不执行的解决方法

    原文:WebBrowser 的 DocumentCompleted事件不执行的解决方法 WebBrowser 的 DocumentCompleted事件不执行的解决方法: 使用WebBrowser的P ...

  3. 事件循环和线程没有必然关系(就像Windows子线程默认没有消息循环一样),模态对话框和事件循环也没有必然关系(QWidget直接就可以)

    周末天冷,索性把电脑抱到床上上网,这几天看了 dbzhang800 博客关于 Qt 事件循环的几篇 Blog,发现自己对 Qt 的事件循环有不少误解.从来只看到现象,这次借 dbzhang800 的博 ...

  4. char、char*、char**数组(有图,非常清楚)good

    平时都用的是char数组,基本忘记了char*数组和char**数组该怎么用了 char s1[10]; s1[0] s1[1]等都是char s1是char*,等同于&s1[0] char* ...

  5. VS2010使用c++、gSOAP创建WebService 图文教程

    VS2010使用c++.gSOAP创建的WebService 图文教程 环境 操作系统:Windows 7gsoap版本:2.8.32C++编译器/开发环境:Visual Studio 2010 gS ...

  6. 京东sdk商家上架接口调用问题总结

    前言: 最近在做商家发布产品,调用京东sdk,发现问题很多,而且还是在我同事的帮助下完成的,摸索中,菜鸟还请高手门多多提携才好,入正题 首先是引用jd的sdk啦,京东sdk中发布商品需要调用一个 36 ...

  7. Realm_King 之 XPDL(XML Process Definition Language)

    XPDL(XML Process Definition Language)是由Workflow Management Coalition(简写为:WfMC)所提出的一个标准化规格,使用XML文件让不同 ...

  8. 30+ 强大的Buddypress主题–开始您的社区站点吧

    BuddyPress起源于2008年,当时设计者设想添加社交网络功能到WordPress多用户版本中.第一个正式稳定版本的发布是在2009年的5月.自从那时起.BuddyPress开始快速的成长和演变 ...

  9. uni-app $refs的基本用法

    $refs的基本用法 一个对象(Object),持有注册过 ref 特性 的所有 DOM 元素和组件实例. <template> <view class="containe ...

  10. ansible(三)

    一.setup模块(收集信息 ) 1.ansible中的setup模块可以收集到的信息 ansible web -m setup ansible_all_ipv4_addresses # ipv4的所 ...