AMS(ActivityManagerService)是Activity管理的核心组件,提供了Activity的启动、生命周期管理、栈管理等功能,熟悉AMS会对我们认识Activity的工作原理有很大的帮助.
AMS中内容实在是太多了,对它的分析也不可能面面俱到,从Activity的启动、Activity消息回传(onActivityResult)、Activity栈管理、AMS与WMS和PMS的协同工作这几个点深入理解一下,通过对源码的流程梳理, 对AMS有进一步的理解.
本篇文章重点关注Activity的生命周期, 通过生命周期方法的执行, 然后继续跟踪Framework层的代码. 在Fwk层的源码分析见: Android ActivityManagerService总结(四)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====");
}
}
跳转图:
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流程