startActivity的生命周期

一. 前言

        AMS(ActivityManagerService)是Activity管理的核心组件,提供了Activity的启动、生命周期管理、栈管理等功能,熟悉AMS会对我们认识Activity的工作原理有很大的帮助.

        AMS中内容实在是太多了,对它的分析也不可能面面俱到,从Activity的启动、Activity消息回传(onActivityResult)、Activity栈管理、AMS与WMS和PMS的协同工作这几个点深入理解一下,通过对源码的流程梳理, 对AMS有进一步的理解.

        本篇文章重点关注Activity的生命周期, 通过生命周期方法的执行, 然后继续跟踪Framework层的代码. 在Fwk层的源码分析见:  Android ActivityManagerService总结(四)startActivity流程

二. startActivity的生命周期

我们用两个App来做演示代码, 一个appA 名称为StartActivityDemo.apk     appB 名称为MyClient.apk

两个app运行在设备上,就是两个独立的进程

1. 在appA 中, 通过MainActivity启动内部的一个SecondActivity  

2. 然后在SecondActivity中启动 appB的 BprocessActivity

模型图:

 两个Demo的关键代码, 我们在每个生命周期方法中加上关键log

1. 进程A的 MainActivity代码:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Log.e("activity", "==进程A===MainActivity onCreate=====");
        setContentView(R.layout.activity_main);

        Button startBtn = findViewById(R.id.start_activity);

        startBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(MainActivity.this, SecondActivity.class);
                //跳转到SecondActivity
                startActivity(intent);
            }
        });
    }

    @Override
    protected void onStart() {
        super.onStart();
        Log.e("activity", "==进程A===MainActivity onStart=====");
    }

    @Override
    protected void onRestart() {
        super.onRestart();
        Log.e("activity", "==进程A===MainActivity onRestart=====");
    }

    @Override
    protected void onResume() {
        super.onResume();
        Log.e("activity", "==进程A===MainActivity onResume=====");
    }


    @Override
    protected void onPause() {
        super.onPause();
        Log.e("activity", "==进程A===MainActivity onPause=====");
    }

    @Override
    protected void onStop() {
        super.onStop();
        Log.e("activity", "==进程A===MainActivity onStop=====");
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        Log.e("activity", "==进程A===MainActivity onDestroy=====");
    }

2. 进程A的 SecondActivity代码

public class SecondActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Log.e("activity", "==进程A===2222222222 onCreate=====");
        setContentView(R.layout.activity_second);

        Button startBprocessBtn = findViewById(R.id.start_processB);
        startBprocessBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent();
                ComponentName componentName = new ComponentName("com.example.myclient",
                        "com.example.myclient.BprocessActivity");
                intent.setComponent(componentName);
                try{
                    //跳转到进程B中的 BprocessActivity
                    startActivity(intent);
                } catch (Exception e) {
                    Log.e("activity", "error:  "+e.getMessage());
                }
            }
        });

    }

    @Override
    protected void onStart() {
        super.onStart();
        Log.e("activity", "==进程A===2222222222 onStart=====");
    }

    @Override
    protected void onRestart() {
        super.onRestart();
        Log.e("activity", "==进程A===2222222222 onRestart=====");
    }

    @Override
    protected void onResume() {
        super.onResume();
        Log.e("activity", "==进程A===2222222222 onResume=====");
    }


    @Override
    protected void onPause() {
        super.onPause();
        Log.e("activity", "==进程A===2222222222 onPause=====");
    }

    @Override
    protected void onStop() {
        super.onStop();
        Log.e("activity", "==进程A===2222222222 onStop=====");
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        Log.e("activity", "==进程A===2222222222 onDestroy=====");
    }

}

3. 进程B  BprocessActivity代码

public class BprocessActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Log.e("activity", "====进程B的 BprocessActivity onCreate====");
    }


    @Override
    protected void onStart() {
        super.onStart();
        Log.e("activity", "====进程B的 BprocessActivity onStart====");
    }


    @Override
    protected void onResume() {
        super.onResume();
        Log.e("activity", "====进程B的 BprocessActivity onResume====");
    }


    @Override
    protected void onStop() {
        super.onStop();
        Log.e("activity", "====进程B的 BprocessActivity onStop====");
    }


    @Override
    protected void onDestroy() {
        super.onDestroy();
        Log.e("activity", "====进程B的 BprocessActivity onDestroy====");
    }

}

三. log打印

跳转图:

3.1 启动appA, 进入主界面MainActivity

04-03 13:12:41.118 24230 24230 E activity: ==进程A===MainActivity onCreate=====
04-03 13:12:41.156 24230 24230 E activity: ==进程A===MainActivity onStart=====
04-03 13:12:41.159 24230 24230 E activity: ==进程A===MainActivity onResume=====

 3.2 点击跳转到SecondActivity按钮

04-03 13:13:17.473 24230 24230 E activity: ==进程A===MainActivity onPause=====
04-03 13:13:17.496 24230 24230 E activity: ==进程A===2222222222 onCreate=====
04-03 13:13:17.539 24230 24230 E activity: ==进程A===2222222222 onStart=====
04-03 13:13:17.541 24230 24230 E activity: ==进程A===2222222222 onResume=====
04-03 13:13:18.045 24230 24230 E activity: ==进程A===MainActivity onStop=====

需要注意的是 MainActivity先是 onPause , 待 SecondActivity显示完成后, 执行 onStop方法

3.3 然后在SecondActivity界面点击跳转到进程B按钮

04-03 13:15:36.686 24230 24230 E activity: ==进程A===2222222222 onPause=====
04-03 13:15:36.750 24289 24289 E activity: ====进程B的 BprocessActivity onCreate====
04-03 13:15:36.753 24289 24289 E activity: ====进程B的 BprocessActivity onStart====
04-03 13:15:36.757 24289 24289 E activity: ====进程B的 BprocessActivity onResume====
04-03 13:15:37.242 24230 24230 E activity: ==进程A===2222222222 onStop=====

同样也是先执行onPause方法,然后待进程B的BprocessActivity显示后, 再执行onStop方法

四. 要弄清楚的问题

通过上面log打印,  有Android基础的开发人员一看就知道是怎么回事, 当然我们需要知其然, 更要知其所以然:

实际上要理解的是下面3个问题,在Framework层的调用流程又是怎么样的.

1. 当在同一个进程中调用startActivity方法的流程是怎么样的?

2. 当启动另外一个进程中的Activity时, startActivity的调用流程又是什么样的?

3. 启动一个新的Activity, 为什么先是执行onPause方法,然后待新界面显示完成后,在执行onStop方法?

这3个问题的答案见笔者的Framework层分析 Android ActivityManagerService总结(四)startActivity流程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 开发 (实验四) 实验题目:Activity生命周期验证试验 指导老师: 班 级:计算机科学与技术系班 姓 名:( 1. 实验目的 1、深入理解Activity运行机制和原理。 2、掌握Activity的声明周期各个阶段工作流程。 3、掌握多个Activity之间生命周期的转换过程。 4、通络Intent实现多页面之间数据的传递(辅助完成)。 2. 实验内容 1. 搭建任意组件,设计多个界面,运行程序观察其生命周期的情况。 2. 使用Intent实现页面之间数据的传递。 3. 实验代码 AlifecyfleActivity.java package com.wr; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; public class AlifecycleActivity extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); Button BtnStart = (Button) findViewById(R.id.BtnStart); BtnStart.setOnClickListener(new MyBtnClickListener()); } @Override protected void onDestroy() { // TODO Auto-generated method stub super.onDestroy(); System.out.println("AlifecycleActivity:onDestroy()"); } @Override protected void onPause() { // TODO Auto-generated method stub super.onPause(); System.out.println("AlifecycleActivity:onPause()"); } @Override protected void onRestart() { // TODO Auto-generated method stub super.onRestart(); System.out.println("AlifecycleActivity:onRestart()"); } @Override protected void onResume() { // TODO Auto-generated method stub super.onResume(); System.out.println("AlifecycleActivity:onResume()"); } @Override protected void onStart() { // TODO Auto-generated method stub super.onStart(); System.out.println("AlifecycleActivity:onStart()"); } @Override protected void onStop() { // TODO Auto-generated method stub super.onStop(); System.out.println("AlifecycleActivity:onStop()"); } public class MyBtnClickListener implements OnClickListener { //重写点击事件处理方法 public void onClick(View arg0) { // TODO Auto-generated method stub Intent intent = new Intent(AlifecycleActivity.this,AlcActivity2.class);//创建意图对象 //使用意图对象打开一个新的Activity startActivity(intent); } } } AlcActivity.java package com.wr; imp

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值