深入Activity生命周期(二)

简介: 下面以Demo来帮助理解Activity生命周期,   布局文件: 只显示一个TextView和一个EditView,Activity代码如下: import android.

  下面以Demo来帮助理解Activity生命周期,

  布局文件:

<?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:id="@+id/tv"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="so many people."
    />
    <EditText 
    android:id="@+id/et"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:hint="hello,world"
    />
</LinearLayout>

只显示一个TextView和一个EditView,
Activity代码如下:

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.EditText;
import android.widget.TextView;

public class AndroidOrientationtestActivity extends Activity 
{
    EditText et;
    TextView tv;
    
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        initUI();
        Log.i("my", "onCreate---");
    }

    private void initUI()
    {
        et = (EditText)findViewById(R.id.et);
        //打印控件的地址,对比切屏前的地址是否为同一个
        Log.i("my", "et="+et.toString());
        tv = (TextView)findViewById(R.id.tv);
      //打印控件的地址,对比切屏前的地址是否为同一个
        Log.i("my", "tv="+tv.toString());
    }
    
    @Override
    protected void onRestart()
    {
        // TODO Auto-generated method stub
        super.onRestart();
        Log.i("my", "onRestart---");
    }


    @Override
    protected void onStart()
    {
        // TODO Auto-generated method stub
        super.onStart();
        Log.i("my", "onStart---");
    }


    @Override
    protected void onResume()
    {
        // TODO Auto-generated method stub
        super.onResume();
        Log.i("my", "onResume---");
    }


    @Override
    protected void onPause()
    {
        // TODO Auto-generated method stub
        super.onPause();
        Log.i("my", "onPause---");
    }

    @Override
    protected void onStop()
    {
        // TODO Auto-generated method stub
        super.onStop();
        Log.i("my", "onStop---");
    }

    @Override
    protected void onDestroy()
    {
        // TODO Auto-generated method stub
        super.onDestroy();
        Log.i("my", "onDestroy---");
    }
    
}

当启动Activity界面的时候,Log如下:

07-30 09:54:26.793: INFO/my(833): et=android.widget.EditText@4051ab70
07-30 09:54:26.793: INFO/my(833): tv=android.widget.TextView@4051a428
07-30 09:54:26.813: INFO/my(833): onCreate---
07-30 09:54:26.813: INFO/my(833): onStart---
07-30 09:54:26.813: INFO/my(833): onResume---

 

 

 

 

可以看到首先启动的是onCreate(),然后是onStart(),然后是onResume(),看得到有了界面。
当按下home键的时候,log如下:

07-30 09:54:26.793: INFO/my(833): et=android.widget.EditText@4051ab70
07-30 09:54:26.793: INFO/my(833): tv=android.widget.TextView@4051a428
07-30 09:54:26.813: INFO/my(833): onCreate---
07-30 09:54:26.813: INFO/my(833): onStart---
07-30 09:54:26.813: INFO/my(833): onResume---
07-30 09:56:31.183: INFO/my(833): onPause---
07-30 09:56:32.018: INFO/my(833): onStop---

可以看到多了onPause(),以及onStop(),

再次按下home键,切回去Activity,Log如下:

07-30 09:54:26.793: INFO/my(833): et=android.widget.EditText@4051ab70
07-30 09:54:26.793: INFO/my(833): tv=android.widget.TextView@4051a428
07-30 09:54:26.813: INFO/my(833): onCreate---
07-30 09:54:26.813: INFO/my(833): onStart---
07-30 09:54:26.813: INFO/my(833): onResume---
07-30 09:56:31.183: INFO/my(833): onPause---
07-30 09:56:32.018: INFO/my(833): onStop---
07-30 09:57:49.303: INFO/my(833): onRestart---
07-30 09:57:49.303: INFO/my(833): onStart---
07-30 09:57:49.303: INFO/my(833): onResume---

在这里执行了onRestart(),onStart(),onResume()方法。
这里因为系统决定回收Activity,这里无法模拟当Activity被停止,然后被回收以后的状态,但是生命周期与新启动一个activity是一样的。

 

如果这时候按下call键,则会弹出对话框,这时候会局部挡住当前的Activity,然后再按返回键,log如下:

07-30 09:54:26.793: INFO/my(833): et=android.widget.EditText@4051ab70
07-30 09:54:26.793: INFO/my(833): tv=android.widget.TextView@4051a428
07-30 09:54:26.813: INFO/my(833): onCreate---
07-30 09:54:26.813: INFO/my(833): onStart---
07-30 09:54:26.813: INFO/my(833): onResume---
07-30 09:56:31.183: INFO/my(833): onPause---
07-30 09:56:32.018: INFO/my(833): onStop---
07-30 09:57:49.303: INFO/my(833): onRestart---
07-30 09:57:49.303: INFO/my(833): onStart---
07-30 09:57:49.303: INFO/my(833): onResume---
07-30 10:01:20.093: INFO/my(833): onPause---
07-30 10:01:32.574: INFO/my(833): onResume---

当对话框挡住activity时,调用了onPause,按下返回键时,重新onResume().

 

 

 

 

 

 

 

 

 

目录
相关文章
|
Android开发
深入剖析Android四大组件(一)——Activity生命周期详解(一)
深入剖析Android四大组件(一)——Activity生命周期详解(一)
570 0
深入剖析Android四大组件(一)——Activity生命周期详解(一)
|
存储 Java 数据库
深入剖析Android四大组件(一)——Activity生命周期详解(二)
深入剖析Android四大组件(一)——Activity生命周期详解(二)
152 0
深入剖析Android四大组件(一)——Activity生命周期详解(二)
|
Android开发
Android四大组件之一Activity生命周期的不同走向
Android四大组件之一Activity的生命周期,欢迎大家阅读
117 0
Android四大组件之一Activity生命周期的不同走向
|
XML Java Android开发
Activity生命周期详解
Activity是由Activity栈进管理,当来到一个新的Activity后,此Activity将被加入到Activity栈顶,之前的Activity位于此Activity底部。
216 0
Activity生命周期详解
聊聊onSaveInstanceState和onRetainNonConfigurationInstance的区别
聊聊onSaveInstanceState和onRetainNonConfigurationInstance的区别
聊聊onSaveInstanceState和onRetainNonConfigurationInstance的区别
|
Java Android开发
Activity的四种启动模式
Android的冷门知识,大家有兴趣可以了解了解
214 0
IntentService详解
IntentService是什么? 这篇文章是之前就写好的,一直没有整理出来,这几天有空正好整理发布一下。 我们知道Service可以让我们在后台处理一些事情,但是Service实际上也是主线程,所以执行长耗时任务时依然会ANR,只不过ANR触发时间要比前台长。一般我们会在Service中开启一个子线程去完成耗时任务。 而IntentService就是解决这个问题的,它是Service的一个抽象子类,需要实现onHandleIntent,代码在这个函数中执行。它与Service最大的不同就是默认开启一个子线程,而onHandleIntent就是在子线程中执行的。
159 0
|
Android开发
Activity四种启动模式
Activity四种启动模式