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

一、主界面:

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. ARTS 1.7 - 1.11

    每周一个 Algorithm,Review 一篇英文文章,总结一个工作中的技术 Tip,以及 Share 一个传递价值观的东西! Algorithm: 学习算法 题目: https://leetcod ...

  2. C语言中.h和.c文件解析(转载)

    转载:http://www.cnblogs.com/laojie4321/archive/2012/03/30/2425015.html   简单的说其实要理解C文件与头文件(即.h)有什么不同之处, ...

  3. 多态与虚拟 : 物件导向的精髓 (侯捷在石器时代对OO的理解)

    [自序]虑而後能得(自序)故事接触 C++ 大约是 1989 年的事.那时候的 PC 以现在的眼光看,除了「蛮荒」之外没有更合适的形容词了.横扫千军的 Windows 3.0 还没有诞生,如今以 C+ ...

  4. 使用PNG实现半透明的窗体(使用GDI+)

      Delphi中标准控件是不支持png图片的,据说从Window2000后增加gdiplus.dll库处理更多的gdi图像,其中包括png.   关键的几个api   GdipCreateBitma ...

  5. 教你如何在 Visual Studio 2013 上使用 Github

    介绍 我承认越是能将事情变简单的工具我越会更多地使用它.尽管我已经知道了足够的命令来使用Github,但我宁愿它被集成到IDE中.在本教程中,我会告诉你使用Visual Studio 2013如何实现 ...

  6. Qt动画效果的幕后英雄:QTimeLine

    其实动画的本质就是在每一定时间间隔内显示一帧图像,当这个间隔较短的时候人眼就感觉不出来了,觉得看到的是连续的影像.Qt为开发动画效果的人员提供了一个很好的时间控制类QTimeLine. QTimeLi ...

  7. Linux使用daemontools

    功能: 在使用memcached时候,怕因为一些不可预知的因素导致memcached进程死掉,而又不能及时的发现重启,可以通过daemontools来管理memcached的启动,当memcached ...

  8. PHP/JS中获取当前页面的完整URL

    javascript实现: top.location.href 顶级窗口的地址this.location.href 当前窗口的地址 php实现 PHP实现 #测试网址: http://localhos ...

  9. 【原创】ABAP根据文件路径获取文件所在目录(续)

    在上一篇文章<ABAP根据文件路径获取文件所在目录>中,我主要的思路是采用 “SPLIT dobj AT sep INTO TABLE result_tab” 句型将文件全路径按分隔符“\ ...

  10. kafka笔记4(2)

    提交和偏移量 每次调用poll 方法,总是返回生产者写入Kafka但还没有被消费者读取过的记录我们因此可以追踪到哪些记录时被群组里的哪个消费者读取过的. 我们把更新分区当前位置的操作叫做提交. 那么消 ...