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流程

猜你喜欢

转载自blog.csdn.net/u012514113/article/details/129926101