Android源码分析 - Activity启动流程(下)

开篇

本篇以android-11.0.0_r25作为基础解析

上一篇文章 Android源码分析 - Activity启动流程(中) 中,我们分析了App进程的启动过程,包括Application是怎么创建并执行onCreate方法的,本篇文章我们将会继续分析App进程启动、Application创建完成后,Activity是如何启动的

两种路径启动Activity

我们在 Android源码分析 - Activity启动流程(上) 的末尾分析过,Activity的启动存在两条路径

启动进程,然后启动Activity

这条路径就是我们在上一篇文章 Android源码分析 - Activity启动流程(中) 中分析了前半部分:启动进程

当进程启动后,会执行到AMS.attachApplicationLocked方法,在这个方法的最后,会有一段代码检查是否有Activity等待启动

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
private boolean attachApplicationLocked(@NonNull IApplicationThread thread,
int pid, int callingUid, long startSeq) {
...

// See if the top visible activity is waiting to run in this process...
//检查是否有Activity等待启动
if (normalMode) {
try {
didSomething = mAtmInternal.attachApplication(app.getWindowProcessController());
} catch (Exception e) {
badApp = true;
}
}

...

return true;
}

然后调用ActivityTaskManagerInternal.attachApplicationActivityTaskManagerInternal是一个抽象类,被ATMS的内部类LocalService实现

1
2
3
4
5
6
7
8
9
public boolean attachApplication(WindowProcessController wpc) throws RemoteException {
synchronized (mGlobalLockWithoutBoost) {
try {
return mRootWindowContainer.attachApplication(wpc);
} finally {
...
}
}
}

接着调用RootWindowContainer.attachApplication

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
boolean attachApplication(WindowProcessController app) throws RemoteException {
boolean didSomething = false;
for (int displayNdx = getChildCount() - 1; displayNdx >= 0; --displayNdx) {
mTmpRemoteException = null;
mTmpBoolean = false; // Set to true if an activity was started.

final DisplayContent display = getChildAt(displayNdx);
for (int areaNdx = display.getTaskDisplayAreaCount() - 1; areaNdx >= 0; --areaNdx) {
final TaskDisplayArea taskDisplayArea = display.getTaskDisplayAreaAt(areaNdx);
for (int taskNdx = taskDisplayArea.getStackCount() - 1; taskNdx >= 0; --taskNdx) {
final ActivityStack rootTask = taskDisplayArea.getStackAt(taskNdx);
if (rootTask.getVisibility(null /*starting*/) == STACK_VISIBILITY_INVISIBLE) {
break;
}
//遍历ActivityStack下的所有ActivityRecord,
//以其为参数调用startActivityForAttachedApplicationIfNeeded方法
final PooledFunction c = PooledLambda.obtainFunction(
RootWindowContainer::startActivityForAttachedApplicationIfNeeded, this,
PooledLambda.__(ActivityRecord.class), app,
rootTask.topRunningActivity());
rootTask.forAllActivities(c);
c.recycle();
if (mTmpRemoteException != null) {
throw mTmpRemoteException;
}
}
}
didSomething |= mTmpBoolean;
}
if (!didSomething) {
ensureActivitiesVisible(null, 0, false /* preserve_windows */);
}
return didSomething;
}

这里有两层for循环,可以看出来,这个方法遍历了所有可见的ActivityStack,然后再对每个可见的ActivityStack进行操作

其中,PooledLambda这个类采用了池化技术,用于构造可回收复用的匿名函数,这里PooledLambda.obtainFunction方法得到的结果是一个Function<ActivityRecord, Boolean>forAllActivities方法被定义在父类WindowContainer中,就是遍历执行所有childforAllActivities方法,而ActivityRecord中重写了这个方法,直接用自身执行这个Function

简单来说,可以将这部分代码看作以下伪代码:

1
2
3
rootTask.forEachAllActivityRecord((activityRecord) -> {
startActivityForAttachedApplicationIfNeeded(activityRecord, app, rootTask.topRunningActivity())
})

接着我们来观察startActivityForAttachedApplicationIfNeeded方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
private boolean startActivityForAttachedApplicationIfNeeded(ActivityRecord r,
WindowProcessController app, ActivityRecord top) {
//Activity是否正在finish,是否应为当前用户显示Activity,忽略锁屏情况,此Activity是否可见
//对比Activity与发起进程的uid和进程名
if (r.finishing || !r.okToShowLocked() || !r.visibleIgnoringKeyguard || r.app != null
|| app.mUid != r.info.applicationInfo.uid || !app.mName.equals(r.processName)) {
return false;
}

try {
//启动Activity
if (mStackSupervisor.realStartActivityLocked(r, app,
top == r && r.isFocusable() /*andResume*/, true /*checkConfig*/)) {
mTmpBoolean = true;
}
} catch (RemoteException e) {
...
return true;
}
return false;
}

上面一系列的判断检查传入的ActivityRecord所对应的Activity是否需要启动,然后调用ActivityStackSupervisor.realStartActivityLocked方法启动Activity

已有进程,直接启动Activity

这条路径我在 Android源码分析 - Activity启动流程(上) 中的末尾也分析过,如果App进程已经启动,则会调用ActivityStackSupervisor.startSpecificActivity方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
void startSpecificActivity(ActivityRecord r, boolean andResume, boolean checkConfig) {
// Is this activity's application already running?
final WindowProcessController wpc =
mService.getProcessController(r.processName, r.info.applicationInfo.uid);

boolean knownToBeDead = false;
if (wpc != null && wpc.hasThread()) {
try {
//启动Activity
realStartActivityLocked(r, wpc, andResume, checkConfig);
return;
} catch (RemoteException e) {
Slog.w(TAG, "Exception when starting activity "
+ r.intent.getComponent().flattenToShortString(), e);
}

// If a dead object exception was thrown -- fall through to
// restart the application.
knownToBeDead = true;
}

//锁屏状态下启动Activity防闪烁机制
r.notifyUnknownVisibilityLaunchedForKeyguardTransition();

//出现异常,重启进程
final boolean isTop = andResume && r.isTopRunningActivity();
mService.startProcessAsync(r, knownToBeDead, isTop, isTop ? "top-activity" : "activity");
}

可以看到,这里也调用了ActivityStackSupervisor.realStartActivityLocked方法启动Activity

realStartActivityLocked

最终两条路径都走到了ActivityStackSupervisor.realStartActivityLocked方法中,那我们就来看看这个方法做了什么

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
boolean realStartActivityLocked(ActivityRecord r, WindowProcessController proc,
boolean andResume, boolean checkConfig) throws RemoteException {

//确保所有Activity都已暂停
if (!mRootWindowContainer.allPausedActivitiesComplete()) {
// While there are activities pausing we skipping starting any new activities until
// pauses are complete. NOTE: that we also do this for activities that are starting in
// the paused state because they will first be resumed then paused on the client side.
return false;
}

final Task task = r.getTask();
final ActivityStack stack = task.getStack();

//延迟resume以避免重复resume
//通过设置标记位mDeferResumeCount,只有当其为0时才能执行resume
beginDeferResume();

try {
//冻结屏幕(不接收输入、不执行动画,截取屏幕进行显示)
r.startFreezingScreenLocked(proc, 0);

// schedule launch ticks to collect information about slow apps.
//收集启动缓慢信息
r.startLaunchTickingLocked();

r.setProcess(proc);

// Ensure activity is allowed to be resumed after process has set.
//确保Activity允许被resume
if (andResume && !r.canResumeByCompat()) {
andResume = false;
}

//锁屏状态下启动Activity防闪烁机制
r.notifyUnknownVisibilityLaunchedForKeyguardTransition();

// Have the window manager re-evaluate the orientation of the screen based on the new
// activity order. Note that as a result of this, it can call back into the activity
// manager with a new orientation. We don't care about that, because the activity is
// not currently running so we are just restarting it anyway.
if (checkConfig) {
// Deferring resume here because we're going to launch new activity shortly.
// We don't want to perform a redundant launch of the same record while ensuring
// configurations and trying to resume top activity of focused stack.
//确保所有Activity的可见性、更新屏幕方向和配置
mRootWindowContainer.ensureVisibilityAndConfig(r, r.getDisplayId(),
false /* markFrozenIfConfigChanged */, true /* deferResume */);
}

//检查Activity是否在后台锁屏状态下启动
if (r.getRootTask().checkKeyguardVisibility(r, true /* shouldBeVisible */,
true /* isTop */) && r.allowMoveToFront()) {
// We only set the visibility to true if the activity is not being launched in
// background, and is allowed to be visible based on keyguard state. This avoids
// setting this into motion in window manager that is later cancelled due to later
// calls to ensure visible activities that set visibility back to false.
//只有Activity不是在后台启动,才将其可见性设置为true
r.setVisibility(true);
}

... //异常情况检查

r.launchCount++;
r.lastLaunchTime = SystemClock.uptimeMillis();
proc.setLastActivityLaunchTime(r.lastLaunchTime);

//屏幕固定功能
final LockTaskController lockTaskController = mService.getLockTaskController();
if (task.mLockTaskAuth == LOCK_TASK_AUTH_LAUNCHABLE
|| task.mLockTaskAuth == LOCK_TASK_AUTH_LAUNCHABLE_PRIV
|| (task.mLockTaskAuth == LOCK_TASK_AUTH_WHITELISTED
&& lockTaskController.getLockTaskModeState()
== LOCK_TASK_MODE_LOCKED)) {
lockTaskController.startLockTaskMode(task, false, 0 /* blank UID */);
}

try {
if (!proc.hasThread()) {
throw new RemoteException();
}
List<ResultInfo> results = null;
List<ReferrerIntent> newIntents = null;
if (andResume) {
// We don't need to deliver new intents and/or set results if activity is going
// to pause immediately after launch.
results = r.results;
newIntents = r.newIntents;
}
//如果是ACTIVITY_TYPE_HOME类型的应用(Launcher)
if (r.isActivityTypeHome()) {
// Home process is the root process of the task.
updateHomeProcess(task.getBottomMostActivity().app);
}
//信息记录
mService.getPackageManagerInternalLocked().notifyPackageUse(
r.intent.getComponent().getPackageName(), NOTIFY_PACKAGE_USE_ACTIVITY);
r.setSleeping(false);
r.forceNewConfig = false;
//如果有必要的话,显示一些App警告弹窗(不支持的CompileSdk、不支持的TargetSdk、不支持的显示大小)
mService.getAppWarningsLocked().onStartActivity(r);
//兼容性信息
r.compat = mService.compatibilityInfoForPackageLocked(r.info.applicationInfo);

// Because we could be starting an Activity in the system process this may not go
// across a Binder interface which would create a new Configuration. Consequently
// we have to always create a new Configuration here.

final MergedConfiguration mergedConfiguration = new MergedConfiguration(
proc.getConfiguration(), r.getMergedOverrideConfiguration());
r.setLastReportedConfiguration(mergedConfiguration);


// Create activity launch transaction.
//创建或获取一个client事务
final ClientTransaction clientTransaction = ClientTransaction.obtain(
proc.getThread(), r.appToken);

final DisplayContent dc = r.getDisplay().mDisplayContent;
//添加一条Activity启动消息
clientTransaction.addCallback(LaunchActivityItem.obtain(new Intent(r.intent),
System.identityHashCode(r), r.info,
// TODO: Have this take the merged configuration instead of separate global
// and override configs.
mergedConfiguration.getGlobalConfiguration(),
mergedConfiguration.getOverrideConfiguration(), r.compat,
r.launchedFromPackage, task.voiceInteractor, proc.getReportedProcState(),
r.getSavedState(), r.getPersistentSavedState(), results, newIntents,
dc.isNextTransitionForward(), proc.createProfilerInfoIfNeeded(),
r.assistToken, r.createFixedRotationAdjustmentsIfNeeded()));

// Set desired final state.
final ActivityLifecycleItem lifecycleItem;
if (andResume) {
lifecycleItem = ResumeActivityItem.obtain(dc.isNextTransitionForward());
} else {
lifecycleItem = PauseActivityItem.obtain();
}
//设置client执行事务后应处于的生命周期状态
clientTransaction.setLifecycleStateRequest(lifecycleItem);

// Schedule transaction.
//调度执行此事务,启动Activity
mService.getLifecycleManager().scheduleTransaction(clientTransaction);

//处理重量级进程
if ((proc.mInfo.privateFlags & ApplicationInfo.PRIVATE_FLAG_CANT_SAVE_STATE) != 0
&& mService.mHasHeavyWeightFeature) {
// This may be a heavy-weight process! Note that the package manager will ensure
// that only activity can run in the main process of the .apk, which is the only
// thing that will be considered heavy-weight.
if (proc.mName.equals(proc.mInfo.packageName)) {
if (mService.mHeavyWeightProcess != null
&& mService.mHeavyWeightProcess != proc) {
Slog.w(TAG, "Starting new heavy weight process " + proc
+ " when already running "
+ mService.mHeavyWeightProcess);
}
mService.setHeavyWeightProcess(r);
}
}

} catch (RemoteException e) {
if (r.launchFailed) {
// This is the second time we failed -- finish activity and give up.
//第二次启动失败,finish掉Activity并放弃重试,直接返回false
Slog.e(TAG, "Second failure launching "
+ r.intent.getComponent().flattenToShortString() + ", giving up", e);
proc.appDied("2nd-crash");
r.finishIfPossible("2nd-crash", false /* oomAdj */);
return false;
}

// This is the first time we failed -- restart process and
// retry.
//第一次启动失败,尝试重启进程并重试启动Activity
r.launchFailed = true;
proc.removeActivity(r);
throw e;
}
} finally {
endDeferResume();
}

r.launchFailed = false;

// TODO(lifecycler): Resume or pause requests are done as part of launch transaction,
// so updating the state should be done accordingly.
//更新生命周期状态
if (andResume && readyToResume()) {
// As part of the process of launching, ActivityThread also performs
// a resume.
stack.minimalResumeActivityLocked(r);
} else {
// This activity is not starting in the resumed state... which should look like we asked
// it to pause+stop (but remain visible), and it has done so and reported back the
// current icicle and other state.
r.setState(PAUSED, "realStartActivityLocked");
mRootWindowContainer.executeAppTransitionForAllDisplay();
}
// Perform OOM scoring after the activity state is set, so the process can be updated with
// the latest state.
//更新进程oom adj,更新进程状态
proc.onStartActivity(mService.mTopProcessState, r.info);

// Launch the new version setup screen if needed. We do this -after-
// launching the initial activity (that is, home), so that it can have
// a chance to initialize itself while in the background, making the
// switch back to it faster and look better.
if (mRootWindowContainer.isTopDisplayFocusedStack(stack)) {
mService.getActivityStartController().startSetupActivity();
}

// Update any services we are bound to that might care about whether
// their client may have activities.
//更新进程绑定的所有服务
if (r.app != null) {
r.app.updateServiceConnectionActivities();
}

return true;
}

这个方法中最关键的部分在于创建了ClientTransaction事务,并向里添加了一条启动Activity的消息,然后调用ATMS.getLifecycleManager.scheduleTransaction调度执行这个事务,启动Activity

ClientTransaction

我们先来看看ClientTransaction这个对象是怎么创建获取的,我们首先调用了ClientTransaction.obtain方法,并传入了一个ActivityThread内部类ApplicationThreadBinder对象IApplicationThread和一个ActivityRecord.Token对象

1
2
3
4
5
6
7
8
9
10
public static ClientTransaction obtain(IApplicationThread client, IBinder activityToken) {
ClientTransaction instance = ObjectPool.obtain(ClientTransaction.class);
if (instance == null) {
instance = new ClientTransaction();
}
instance.mClient = client;
instance.mActivityToken = activityToken;

return instance;
}

这个方法很简单,从池子里拿一个实例,或者新创建一个实例对象,将这个实例对象的两个成员变量赋值后返回

然后我们调用了ClientTransaction.addCallback方法将ClientTransactionItem加入到回调队列中,ClientTransactionItem是一条能够被执行的生命周期回调消息,它是一个抽象类,子类需要实现它的preExecuteexecutepostExecute方法

我们这里传入的是LaunchActivityItem,这条消息是用来启动Activity

然后我们调用ClientTransaction.setLifecycleStateRequest设置当事务执行结束后,Activity应该处在一个怎样的生命周期

最后调用ATMS.getLifecycleManager.scheduleTransaction调度执行这个事务,ATMS.getLifecycleManager获得的是一个ClientLifecycleManager对象,我们沿着这个方法继续往下看

1
2
3
4
5
6
7
8
9
10
void scheduleTransaction(ClientTransaction transaction) throws RemoteException {
final IApplicationThread client = transaction.getClient();
transaction.schedule();
if (!(client instanceof Binder)) {
// If client is not an instance of Binder - it's a remote call and at this point it is
// safe to recycle the object. All objects used for local calls will be recycled after
// the transaction is executed on client in ActivityThread.
transaction.recycle();
}
}

除了回收调用recycle之外,我们又回到了ClientTransaction中,调用其schedule方法

1
2
3
public void schedule() throws RemoteException {
mClient.scheduleTransaction(this);
}

这里又跨进程回到了App进程中,调用ApplicationThread.scheduleTransaction

1
2
3
public void scheduleTransaction(ClientTransaction transaction) throws RemoteException {
ActivityThread.this.scheduleTransaction(transaction);
}

最后调用ActivityThread.scheduleTransaction执行事务,ActivityThread继承自ClientTransactionHandlerscheduleTransaction方法是在这里面定义的

1
2
3
4
void scheduleTransaction(ClientTransaction transaction) {
transaction.preExecute(this);
sendMessage(ActivityThread.H.EXECUTE_TRANSACTION, transaction);
}

首先,调用ClientTransaction.preExecute方法,然后通过Handler发送执行一条EXECUTE_TRANSACTION消息,我们先看一下preExecute

1
2
3
4
5
6
7
8
9
10
11
public void preExecute(android.app.ClientTransactionHandler clientTransactionHandler) {
if (mActivityCallbacks != null) {
final int size = mActivityCallbacks.size();
for (int i = 0; i < size; ++i) {
mActivityCallbacks.get(i).preExecute(clientTransactionHandler, mActivityToken);
}
}
if (mLifecycleStateRequest != null) {
mLifecycleStateRequest.preExecute(clientTransactionHandler, mActivityToken);
}
}

可以看到,就是遍历整个callback列表,执行preExecute方法,最后再执行LifecycleStateRequestpreExecute方法,对应到Activity启动流程中,就是先执行LaunchActivityItem.preExecute,再执行ResumeActivityItem.preExecute

1
2
3
4
5
6
// LaunchActivityItem
public void preExecute(ClientTransactionHandler client, IBinder token) {
client.countLaunchingActivities(1);
client.updateProcessState(mProcState, false);
client.updatePendingConfiguration(mCurConfig);
}
1
2
3
4
5
6
7
// ResumeActivityItem
public void preExecute(ClientTransactionHandler client, IBinder token) {
//这里mUpdateProcState为false,不执行
if (mUpdateProcState) {
client.updateProcessState(mProcState, false);
}
}

都是一些状态更新之类的东西,我们就直接跳过,然后我们看ActivityThread在收到EXECUTE_TRANSACTION消息后做了什么

1
2
3
4
5
6
7
8
9
10
11
12
public void handleMessage(Message msg) {
switch (msg.what) {
...
case EXECUTE_TRANSACTION:
final ClientTransaction transaction = (ClientTransaction) msg.obj;
mTransactionExecutor.execute(transaction);
...
break;
...
}
...
}

这里可以看到,调用了TransactionExecutor对象的execute方法,TransactionExecutor对象在ActivityThread创建时便创建了,内部持有一个ClientTransactionHandler引用,即ActivityThread自身

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
public void execute(ClientTransaction transaction) {
final IBinder token = transaction.getActivityToken();
//处理需要销毁的Activities
if (token != null) {
final Map<IBinder, ClientTransactionItem> activitiesToBeDestroyed =
mTransactionHandler.getActivitiesToBeDestroyed();
final ClientTransactionItem destroyItem = activitiesToBeDestroyed.get(token);
if (destroyItem != null) {
if (transaction.getLifecycleStateRequest() == destroyItem) {
// It is going to execute the transaction that will destroy activity with the
// token, so the corresponding to-be-destroyed record can be removed.
activitiesToBeDestroyed.remove(token);
}
if (mTransactionHandler.getActivityClient(token) == null) {
// The activity has not been created but has been requested to destroy, so all
// transactions for the token are just like being cancelled.
//Activity尚未被创建就被请求destroy,直接取消整个事务
Slog.w(TAG, tId(transaction) + "Skip pre-destroyed transaction:\n"
+ transactionToString(transaction, mTransactionHandler));
return;
}
}
}

executeCallbacks(transaction);

executeLifecycleState(transaction);
mPendingActions.clear();
}

处理需要销毁的Activities这里我们不关注,就直接跳过,然后就是分别执行各个ClientTransactionItem回调消息,最后让其调度执行我们设置的最终的生命周期

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
public void executeCallbacks(ClientTransaction transaction) {
final List<ClientTransactionItem> callbacks = transaction.getCallbacks();
if (callbacks == null || callbacks.isEmpty()) {
// No callbacks to execute, return early.
return;
}

final IBinder token = transaction.getActivityToken();
ActivityClientRecord r = mTransactionHandler.getActivityClient(token);

... //生命周期转换相关

final int size = callbacks.size();
for (int i = 0; i < size; ++i) {
final ClientTransactionItem item = callbacks.get(i);
... //生命周期转换,在Activity启动时不会走进这个case

item.execute(mTransactionHandler, token, mPendingActions);
item.postExecute(mTransactionHandler, token, mPendingActions);
if (r == null) {
// Launch activity request will create an activity record.
//在执行完启动Activity后会新建一个ActivityClientRecord,重新赋值
r = mTransactionHandler.getActivityClient(token);
}

... //生命周期转换,在Activity启动时不会走进这个case
}
}

关于生命周期转换,由于Activity启动的当前阶段不会进入这些case,所以这里就不提了

经过简化,实际上也就执行了LaunchActivityItem.executeLaunchActivityItem.postExecute方法

1
2
3
4
5
6
7
8
public void execute(ClientTransactionHandler client, IBinder token,
PendingTransactionActions pendingActions) {
ActivityClientRecord r = new ActivityClientRecord(token, mIntent, mIdent, mInfo,
mOverrideConfig, mCompatInfo, mReferrer, mVoiceInteractor, mState, mPersistentState,
mPendingResults, mPendingNewIntents, mIsForward,
mProfilerInfo, client, mAssistToken, mFixedRotationAdjustments);
client.handleLaunchActivity(r, pendingActions, null /* customIntent */);
}

这里使用之前在AMS中创建LaunchActivityItem所使用到的信息,创建了一个ActivityClientRecord对象,接着回到ActivityThread,调用其handleLaunchActivity方法

handleLaunchActivity

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
public Activity handleLaunchActivity(ActivityClientRecord r,
PendingTransactionActions pendingActions, Intent customIntent) {
// If we are getting ready to gc after going to the background, well
// we are back active so skip it.
unscheduleGcIdler();
mSomeActivitiesChanged = true;

if (r.profilerInfo != null) {
mProfiler.setProfiler(r.profilerInfo);
mProfiler.startProfiling();
}

// Make sure we are running with the most recent config.
//确保Configuration为最新
handleConfigurationChanged(null, null);

// Initialize before creating the activity
//初始化硬件加速
if (!ThreadedRenderer.sRendererDisabled
&& (r.activityInfo.flags & ActivityInfo.FLAG_HARDWARE_ACCELERATED) != 0) {
HardwareRenderer.preload();
}
//确保WMS被初始化
WindowManagerGlobal.initialize();

// Hint the GraphicsEnvironment that an activity is launching on the process.
//通知有Activity启动
GraphicsEnvironment.hintActivityLaunch();

//执行启动Activity
final Activity a = performLaunchActivity(r, customIntent);

if (a != null) {
//设置Configuration
r.createdConfig = new Configuration(mConfiguration);
reportSizeConfigurations(r);
//设置一些延迟执行的动作(作用域到整个ClientTransaction结束)
if (!r.activity.mFinished && pendingActions != null) {
pendingActions.setOldState(r.state);
//当Activity生命周期走到onStart前,会通过这里设置的值
//判断是否需要执行onRestoreInstanceState、onPostCreate
pendingActions.setRestoreInstanceState(true);
pendingActions.setCallOnPostCreate(true);
}
} else {
// If there was an error, for any reason, tell the activity manager to stop us.
//出现错误,停止启动Activity
try {
ActivityTaskManager.getService()
.finishActivity(r.token, Activity.RESULT_CANCELED, null,
Activity.DONT_FINISH_TASK_WITH_ACTIVITY);
} catch (RemoteException ex) {
throw ex.rethrowFromSystemServer();
}
}

return a;
}

这个方法中,最重要的莫过于performLaunchActivity了,它是创建Activity的核心方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/**  Core implementation of activity launch. */
private Activity performLaunchActivity(ActivityClientRecord r, Intent customIntent) {
ActivityInfo aInfo = r.activityInfo;
//设置LoadedApk
if (r.packageInfo == null) {
r.packageInfo = getPackageInfo(aInfo.applicationInfo, r.compatInfo,
Context.CONTEXT_INCLUDE_CODE);
}

ComponentName component = r.intent.getComponent();
if (component == null) {
component = r.intent.resolveActivity(
mInitialApplication.getPackageManager());
r.intent.setComponent(component);
}

//如果启动的Activity是一个activity-alias,将Component设置为真正的Activity组件
//详见:https://developer.android.com/guide/topics/manifest/activity-alias-element?hl=zh-cn
if (r.activityInfo.targetActivity != null) {
component = new ComponentName(r.activityInfo.packageName,
r.activityInfo.targetActivity);
}

//为Activity创建BaseContext
ContextImpl appContext = createBaseContextForActivity(r);
Activity activity = null;
try {
java.lang.ClassLoader cl = appContext.getClassLoader();
//实例化Activity
activity = mInstrumentation.newActivity(
cl, component.getClassName(), r.intent);
StrictMode.incrementExpectedActivityCount(activity.getClass());
r.intent.setExtrasClassLoader(cl);
r.intent.prepareToEnterProcess();
if (r.state != null) {
r.state.setClassLoader(cl);
}
} catch (Exception e) {
...
}

try {
//创建或获取Application
//如果该Activity指定在其他的一个新的进程中启动(设置了android:process属性),则会新创建Application
//正常不涉及多进程,都是直接获取之前创建好的Application
Application app = r.packageInfo.makeApplication(false, mInstrumentation);

if (activity != null) {
//Manifest中Activity标签下的label属性
CharSequence title = r.activityInfo.loadLabel(appContext.getPackageManager());
//准备Configuration
Configuration config = new Configuration(mCompatConfiguration);
if (r.overrideConfig != null) {
config.updateFrom(r.overrideConfig);
}
Window window = null;
//当relaunch Activity的时候mPreserveWindow才会为true(比如说调用Activity.recreate方法)
if (r.mPendingRemoveWindow != null && r.mPreserveWindow) {
window = r.mPendingRemoveWindow;
r.mPendingRemoveWindow = null;
r.mPendingRemoveWindowManager = null;
}

// Activity resources must be initialized with the same loaders as the
// application context.
//设置Activity Resource的Loaders与Application Resource的Loaders一致
appContext.getResources().addLoaders(
app.getResources().getLoaders().toArray(new ResourcesLoader[0]));

appContext.setOuterContext(activity);
//重要:绑定BaseContext、创建PhoneWindow等一系列初始化工作
activity.attach(appContext, this, getInstrumentation(), r.token,
r.ident, app, r.intent, r.activityInfo, title, r.parent,
r.embeddedID, r.lastNonConfigurationInstances, config,
r.referrer, r.voiceInteractor, window, r.configCallback,
r.assistToken);

if (customIntent != null) {
activity.mIntent = customIntent;
}
r.lastNonConfigurationInstances = null;
//更新网络状态
checkAndBlockForNetworkAccess();
activity.mStartedActivity = false;
//设置主题
int theme = r.activityInfo.getThemeResource();
if (theme != 0) {
activity.setTheme(theme);
}

activity.mCalled = false;
//调用Activity的onCreate方法
if (r.isPersistable()) {
mInstrumentation.callActivityOnCreate(activity, r.state, r.persistentState);
} else {
mInstrumentation.callActivityOnCreate(activity, r.state);
}
if (!activity.mCalled) {
//在执行完super.onCreate方法后,mCalled会被置为true
//如果mCalled为false,说明没有执行super.onCreate方法
throw new SuperNotCalledException(
"Activity " + r.intent.getComponent().toShortString() +
" did not call through to super.onCreate()");
}
r.activity = activity;
mLastReportedWindowingMode.put(activity.getActivityToken(),
config.windowConfiguration.getWindowingMode());
}
//设置生命周期状态为onCreate
r.setState(ON_CREATE);

// updatePendingActivityConfiguration() reads from mActivities to update
// ActivityClientRecord which runs in a different thread. Protect modifications to
// mActivities to avoid race.
//将新建的ActivityClientRecord添加到mActivities中
synchronized (mResourcesManager) {
mActivities.put(r.token, r);
}

} catch (SuperNotCalledException e) {
throw e;

} catch (Exception e) {
...
}

return activity;
}

这个方法主要做了以下几个工作:

  1. 准备创建Activity所必要的信息,譬如类名等

  2. Activity创建BaseContext

  3. 通过Instrumentation实例化Activity

  4. 创建或获取Activity进程所对应的Application

  5. 初始化Activity,执行各种绑定工作,创建PhoneWindow

  6. 执行ActivityonCreate生命周期方法

  7. ActivityClientRecord生命周期状态设置为onCreate

我们重点看一下最主要的实例化、attachonCreate这三点

Instrumentation.newActivity

我们在 Android源码分析 - Activity启动流程(中) 中分析了,Application是怎么通过Instrumentation创建的,Activity的创建和它类似

1
2
3
4
5
6
7
8
public Activity newActivity(ClassLoader cl, String className,
Intent intent)
throws InstantiationException, IllegalAccessException,
ClassNotFoundException {
String pkg = intent != null && intent.getComponent() != null
? intent.getComponent().getPackageName() : null;
return getFactory(pkg).instantiateActivity(cl, className, intent);
}

同样的使用了AppComponentFactory创建,我们还是去看一下它的默认实现

1
2
3
4
5
public @NonNull Activity instantiateActivity(@NonNull ClassLoader cl, @NonNull String className,
@Nullable Intent intent)
throws InstantiationException, IllegalAccessException, ClassNotFoundException {
return (Activity) cl.loadClass(className).newInstance();
}

同样的,也是通过类名反射创建一个Activity的实例

Activity.attach

紧接着,我们来看Activity.attach方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
final void attach(Context context, ActivityThread aThread,
Instrumentation instr, IBinder token, int ident,
Application application, Intent intent, ActivityInfo info,
CharSequence title, Activity parent, String id,
NonConfigurationInstances lastNonConfigurationInstances,
Configuration config, String referrer, IVoiceInteractor voiceInteractor,
Window window, ActivityConfigCallback activityConfigCallback, IBinder assistToken) {
//绑定BaseContext
attachBaseContext(context);
//初始化Fragment控制器
mFragments.attachHost(null /*parent*/);

//创建并设置Window用于显示界面
mWindow = new PhoneWindow(this, window, activityConfigCallback);
mWindow.setWindowControllerCallback(mWindowControllerCallback);
mWindow.setCallback(this);
mWindow.setOnWindowDismissedCallback(this);
mWindow.getLayoutInflater().setPrivateFactory(this);
if (info.softInputMode != WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPECIFIED) {
mWindow.setSoftInputMode(info.softInputMode);
}
if (info.uiOptions != 0) {
mWindow.setUiOptions(info.uiOptions);
}

//各成员变量初始化
mUiThread = Thread.currentThread();

mMainThread = aThread;
mInstrumentation = instr;
mToken = token;
mAssistToken = assistToken;
mIdent = ident;
mApplication = application;
mIntent = intent;
mReferrer = referrer;
mComponent = intent.getComponent();
mActivityInfo = info;
mTitle = title;
mParent = parent;
mEmbeddedID = id;
mLastNonConfigurationInstances = lastNonConfigurationInstances;
if (voiceInteractor != null) {
if (lastNonConfigurationInstances != null) {
mVoiceInteractor = lastNonConfigurationInstances.voiceInteractor;
} else {
mVoiceInteractor = new VoiceInteractor(voiceInteractor, this, this,
Looper.myLooper());
}
}

//设置WindowManager、ActivityRecordToken以及是否使用硬件加速
mWindow.setWindowManager(
(WindowManager)context.getSystemService(Context.WINDOW_SERVICE),
mToken, mComponent.flattenToString(),
(info.flags & ActivityInfo.FLAG_HARDWARE_ACCELERATED) != 0);
if (mParent != null) {
mWindow.setContainer(mParent.getWindow());
}
mWindowManager = mWindow.getWindowManager();
mCurrentConfig = config;

mWindow.setColorMode(info.colorMode);
mWindow.setPreferMinimalPostProcessing(
(info.flags & ActivityInfo.FLAG_PREFER_MINIMAL_POST_PROCESSING) != 0);

//设置自动填充选项
setAutofillOptions(application.getAutofillOptions());
//设置内容捕获功能
setContentCaptureOptions(application.getContentCaptureOptions());
}

这里可以看到,attach方法主要做了以下几件事:

  1. 绑定BaseContext

  2. 初始化Fragment控制器

  3. 创建并设置Window

  4. 各种成员变量及其他属性初始化

看完这个方法,我们可以发现,原来ActivityWindow是在这个时候创建的,并且Window的具体实现类为PhoneWindow

再然后便是通过Instrumentation执行ActivityonCreate生命周期方法了

1
2
3
4
5
public void callActivityOnCreate(Activity activity, Bundle icicle) {
prePerformCreate(activity);
activity.performCreate(icicle);
postPerformCreate(activity);
}

其中prePerformCreatepostPerformCreate似乎只有在单元测试和CTS测试下才会产生实质性的影响,在正常情况下我们就当作它们不存在,我们接着看performCreate方法

Activity.performCreate

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
final void performCreate(Bundle icicle) {
performCreate(icicle, null);
}

final void performCreate(Bundle icicle, PersistableBundle persistentState) {
//分发PreCreated事件,执行所有注册的ActivityLifecycleCallbacks的onActivityPreCreated回调
dispatchActivityPreCreated(icicle);
mCanEnterPictureInPicture = true;
// initialize mIsInMultiWindowMode and mIsInPictureInPictureMode before onCreate
final int windowingMode = getResources().getConfiguration().windowConfiguration
.getWindowingMode();
//多窗口模式
mIsInMultiWindowMode = inMultiWindowMode(windowingMode);
//画中画模式(小窗播放视频等场景)
mIsInPictureInPictureMode = windowingMode == WINDOWING_MODE_PINNED;
//恢复请求权限中的标志位
restoreHasCurrentPermissionRequest(icicle);
//执行onCreate生命周期方法
if (persistentState != null) {
onCreate(icicle, persistentState);
} else {
onCreate(icicle);
}
//共享元素动画相关
mActivityTransitionState.readState(icicle);

mVisibleFromClient = !mWindow.getWindowStyle().getBoolean(
com.android.internal.R.styleable.Window_windowNoDisplay, false);
//FragmentManager分发ACTIVITY_CREATED状态
mFragments.dispatchActivityCreated();
//共享元素动画相关
mActivityTransitionState.setEnterActivityOptions(this, getActivityOptions());
//分发PostCreated事件,执行所有注册的ActivityLifecycleCallbacks的onActivityPostCreated回调
dispatchActivityPostCreated(icicle);
}

其中的参数icicle就是我们平时重写Activity.onCreate方法时的第一个入参savedInstanceState,如果Activity发生了重建之类的情况,它会保存一些状态数据,第一次启动Activity时为null

无论persistentState是否为null,最终都会进入到单个参数的onCreate方法中

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
protected void onCreate(@Nullable Bundle savedInstanceState) {
//恢复LoaderManager
if (mLastNonConfigurationInstances != null) {
mFragments.restoreLoaderNonConfig(mLastNonConfigurationInstances.loaders);
}
//ActionBar
if (mActivityInfo.parentActivityName != null) {
if (mActionBar == null) {
mEnableDefaultActionBarUp = true;
} else {
mActionBar.setDefaultDisplayHomeAsUpEnabled(true);
}
}
if (savedInstanceState != null) {
//自动填充功能
mAutoFillResetNeeded = savedInstanceState.getBoolean(AUTOFILL_RESET_NEEDED, false);
mLastAutofillId = savedInstanceState.getInt(LAST_AUTOFILL_ID,
View.LAST_APP_AUTOFILL_ID);

if (mAutoFillResetNeeded) {
getAutofillManager().onCreate(savedInstanceState);
}

//恢复FragmentManager状态
Parcelable p = savedInstanceState.getParcelable(FRAGMENTS_TAG);
mFragments.restoreAllState(p, mLastNonConfigurationInstances != null
? mLastNonConfigurationInstances.fragments : null);
}
//FragmentManager分发CREATED状态,执行内部Fragment的生命周期
mFragments.dispatchCreate();
//分发Created事件,执行所有注册的ActivityLifecycleCallbacks的onActivityCreated回调
dispatchActivityCreated(savedInstanceState);
//语音交互功能
if (mVoiceInteractor != null) {
mVoiceInteractor.attachActivity(this);
}
mRestoredFromBundle = savedInstanceState != null;
//这里表示已调用过super.onCreate方法
mCalled = true;
}

到这里,ActivityonCreate生命周期就走完了,我们也可以从这整个流程中得到一些新的收获,比如说,原来注册在Application中的ActivityLifecycleCallbacks回调是在这里触发的,FragmentManager状态分发的顺序是这样的,为什么必须要调用super.onCreate方法等等

接着,我们再回到TransactionExecutor中,它接下来执行的是LaunchActivityItem.postExecute

1
2
3
4
public void postExecute(ClientTransactionHandler client, IBinder token,
PendingTransactionActions pendingActions) {
client.countLaunchingActivities(-1);
}

这里就非常简单了,计数器减一

postExecute执行完后,整个LaunchActivityItem的工作就完成了,接下来执行的是TransactionExecutor.executeLifecycleState方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
private void executeLifecycleState(ClientTransaction transaction) {
final ActivityLifecycleItem lifecycleItem = transaction.getLifecycleStateRequest();
if (lifecycleItem == null) {
// No lifecycle request, return early.
return;
}

final IBinder token = transaction.getActivityToken();
final ActivityClientRecord r = mTransactionHandler.getActivityClient(token);

if (r == null) {
// Ignore requests for non-existent client records for now.
return;
}

// Cycle to the state right before the final requested state.
//excludeLastState为true的情况下,推进生命周期直到最终生命周期的上一个生命周期
//excludeLastState为false的情况下,推进生命周期直到最终生命周期
cycleToPath(r, lifecycleItem.getTargetState(), true /* excludeLastState */, transaction);

// Execute the final transition with proper parameters.
//执行最终的生命周期事务
lifecycleItem.execute(mTransactionHandler, token, mPendingActions);
lifecycleItem.postExecute(mTransactionHandler, token, mPendingActions);
}

我们目前处在的生命周期为ON_CREATE最终目标要到达的生命周期为ON_RESUMEcycleToPath方法会帮助我们把生命周期推进到ON_RESUME的上一个生命周期也就是ON_START

1
2
3
4
5
6
private void cycleToPath(ActivityClientRecord r, int finish, boolean excludeLastState,
ClientTransaction transaction) {
final int start = r.getLifecycleState();
final IntArray path = mHelper.getLifecyclePath(start, finish, excludeLastState);
performLifecycleSequence(r, path, transaction);
}

TransactionExecutorHelper.getLifecyclePath方法会帮我们计算出一个剩余要经过的生命周期路线的一个有序数组

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
public IntArray getLifecyclePath(int start, int finish, boolean excludeLastState) {
... //错误判断

mLifecycleSequence.clear();
if (finish >= start) {
if (start == ON_START && finish == ON_STOP) {
// A case when we from start to stop state soon, we don't need to go
// through the resumed, paused state.
mLifecycleSequence.add(ON_STOP);
} else {
// just go there
//按顺序添加生命周期
for (int i = start + 1; i <= finish; i++) {
mLifecycleSequence.add(i);
}
}
} else { // finish < start, can't just cycle down
if (start == ON_PAUSE && finish == ON_RESUME) {
// Special case when we can just directly go to resumed state.
mLifecycleSequence.add(ON_RESUME);
} else if (start <= ON_STOP && finish >= ON_START) {
// Restart and go to required state.

// Go to stopped state first.
for (int i = start + 1; i <= ON_STOP; i++) {
mLifecycleSequence.add(i);
}
// Restart
mLifecycleSequence.add(ON_RESTART);
// Go to required state
for (int i = ON_START; i <= finish; i++) {
mLifecycleSequence.add(i);
}
} else {
// Relaunch and go to required state

// Go to destroyed state first.
for (int i = start + 1; i <= ON_DESTROY; i++) {
mLifecycleSequence.add(i);
}
// Go to required state
for (int i = ON_CREATE; i <= finish; i++) {
mLifecycleSequence.add(i);
}
}
}

// Remove last transition in case we want to perform it with some specific params.
if (excludeLastState && mLifecycleSequence.size() != 0) {
mLifecycleSequence.remove(mLifecycleSequence.size() - 1);
}

return mLifecycleSequence;
}

其实从这个方法,我们就能看出Activity生命周期是怎么设计的,代码很简单,我就不解释了

1
2
3
4
5
6
7
8
9
public static final int UNDEFINED = -1;
public static final int PRE_ON_CREATE = 0;
public static final int ON_CREATE = 1;
public static final int ON_START = 2;
public static final int ON_RESUME = 3;
public static final int ON_PAUSE = 4;
public static final int ON_STOP = 5;
public static final int ON_DESTROY = 6;
public static final int ON_RESTART = 7;

我们结合这上面这个生命周期大小来看,startON_CREATEfinishON_RESUMEexcludeLastStatetrue移除最后一个生命周期,得出的结果便是[ON_START],然后调用performLifecycleSequence方法执行生命周期

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
private void performLifecycleSequence(ActivityClientRecord r, IntArray path,
ClientTransaction transaction) {
final int size = path.size();
for (int i = 0, state; i < size; i++) {
state = path.get(i);
switch (state) {
case ON_CREATE:
mTransactionHandler.handleLaunchActivity(r, mPendingActions,
null /* customIntent */);
break;
case ON_START:
mTransactionHandler.handleStartActivity(r, mPendingActions,
null /* activityOptions */);
break;
case ON_RESUME:
mTransactionHandler.handleResumeActivity(r, false /* finalStateRequest */,
r.isForward, "LIFECYCLER_RESUME_ACTIVITY");
break;
case ON_PAUSE:
mTransactionHandler.handlePauseActivity(r, false /* finished */,
false /* userLeaving */, 0 /* configChanges */,
false /* autoEnteringPip */, mPendingActions,
"LIFECYCLER_PAUSE_ACTIVITY");
break;
case ON_STOP:
mTransactionHandler.handleStopActivity(r, 0 /* configChanges */,
mPendingActions, false /* finalStateRequest */,
"LIFECYCLER_STOP_ACTIVITY");
break;
case ON_DESTROY:
mTransactionHandler.handleDestroyActivity(r, false /* finishing */,
0 /* configChanges */, false /* getNonConfigInstance */,
"performLifecycleSequence. cycling to:" + path.get(size - 1));
break;
case ON_RESTART:
mTransactionHandler.performRestartActivity(r, false /* start */);
break;
default:
throw new IllegalArgumentException("Unexpected lifecycle state: " + state);
}
}
}

这个方法很简单啊,就是遍历这个数组,依次执行生命周期,结合我们传入的数组[ON_START],最后便是调用ActivityThread.handleStartActivity方法

handleStartActivity

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
public void handleStartActivity(IBinder token, PendingTransactionActions pendingActions) {
final ActivityClientRecord r = mActivities.get(token);
final Activity activity = r.activity;
... //检查

unscheduleGcIdler();

// Start
//执行onStart生命周期
activity.performStart("handleStartActivity");
//设置生命周期状态为onStart
r.setState(ON_START);

if (pendingActions == null) {
// No more work to do.
return;
}

// Restore instance state
//之前在handleLaunchActivity方法中设置了pendingActions.setRestoreInstanceState(true)
//这里便会判断是否需要并执行Activity.onRestoreInstanceState
if (pendingActions.shouldRestoreInstanceState()) {
if (r.isPersistable()) {
if (r.state != null || r.persistentState != null) {
mInstrumentation.callActivityOnRestoreInstanceState(activity, r.state,
r.persistentState);
}
} else if (r.state != null) {
mInstrumentation.callActivityOnRestoreInstanceState(activity, r.state);
}
}

// Call postOnCreate()
//之前在handleLaunchActivity方法中设置了pendingActions.setCallOnPostCreate(true)
//这里便会执行Activity.onPostCreate,如果不是从onCreate转到onStart,不会进入此case
if (pendingActions.shouldCallOnPostCreate()) {
activity.mCalled = false;
//调用Activity.onPostCreate
if (r.isPersistable()) {
mInstrumentation.callActivityOnPostCreate(activity, r.state,
r.persistentState);
} else {
mInstrumentation.callActivityOnPostCreate(activity, r.state);
}
if (!activity.mCalled) {
//和onCreate一样,onPostCreate也必须要调用super.onPostCreate
throw new SuperNotCalledException(
"Activity " + r.intent.getComponent().toShortString()
+ " did not call through to super.onPostCreate()");
}
}

//更新可见性
//Activity启动时,由于此时mDecor还未赋值,所以不会产生影响
updateVisibility(r, true /* show */);
mSomeActivitiesChanged = true;
}

这里有一点需要注意,我们一般重写ActivityonCreate方法,在其中调用setContentView方法,此时DecorView虽然被创建出来了,但是只在PhoneWindow中持有,尚未给Activity.mDecor赋值,所以此时调用updateVisibility方法并不会将DecorView加入到WindowManager中,也就是目前界面还尚未可见

另外,我们可以注意到,performStart是先于callActivityOnPostCreate,所以Activity中的生命周期回调onPostCreate是在onStart之后触发的,各位在开发App的时候不要弄错了这一点

其他的地方注释都写的都很明白了哈,也没什么必要再看performStart了,无非也就和performCreate一样,执行ActivityLifecycleCallbacks回调,FragmentManager分发STARTED状态,调用onStart方法等

接下来我们再回到TransactionExecutor中,后面便是执行ResumeActivityItemexecutepostExecute方法了

1
2
3
4
5
public void execute(ClientTransactionHandler client, ActivityClientRecord r,
PendingTransactionActions pendingActions) {
client.handleResumeActivity(r, true /* finalStateRequest */, mIsForward,
"RESUME_ACTIVITY");
}

可以看到,又执行了ActivityThread.handleResumeActivity方法

handleResumeActivity

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
public void handleResumeActivity(IBinder token, boolean finalStateRequest, boolean isForward,
String reason) {
// If we are getting ready to gc after going to the background, well
// we are back active so skip it.
unscheduleGcIdler();
mSomeActivitiesChanged = true;

// TODO Push resumeArgs into the activity for consideration
//执行onResume生命周期
final ActivityClientRecord r = performResumeActivity(token, finalStateRequest, reason);
if (r == null) {
// We didn't actually resume the activity, so skipping any follow-up actions.
return;
}
//如果Activity将被destroy,那就没必要再执行resume了,直接返回
if (mActivitiesToBeDestroyed.containsKey(token)) {
// Although the activity is resumed, it is going to be destroyed. So the following
// UI operations are unnecessary and also prevents exception because its token may
// be gone that window manager cannot recognize it. All necessary cleanup actions
// performed below will be done while handling destruction.
return;
}

final Activity a = r.activity;

final int forwardBit = isForward
? WindowManager.LayoutParams.SOFT_INPUT_IS_FORWARD_NAVIGATION : 0;

// If the window hasn't yet been added to the window manager,
// and this guy didn't finish itself or start another activity,
// then go ahead and add the window.
boolean willBeVisible = !a.mStartedActivity;
if (!willBeVisible) {
try {
willBeVisible = ActivityTaskManager.getService().willActivityBeVisible(
a.getActivityToken());
} catch (RemoteException e) {
throw e.rethrowFromSystemServer();
}
}
//设置Window
if (r.window == null && !a.mFinished && willBeVisible) {
r.window = r.activity.getWindow();
View decor = r.window.getDecorView();
//DecorView暂时不可见
decor.setVisibility(View.INVISIBLE);
ViewManager wm = a.getWindowManager();
WindowManager.LayoutParams l = r.window.getAttributes();
//给Activity的mDecor成员变量赋值
a.mDecor = decor;
l.type = WindowManager.LayoutParams.TYPE_BASE_APPLICATION;
l.softInputMode |= forwardBit;
if (r.mPreserveWindow) {
a.mWindowAdded = true;
r.mPreserveWindow = false;
// Normally the ViewRoot sets up callbacks with the Activity
// in addView->ViewRootImpl#setView. If we are instead reusing
// the decor view we have to notify the view root that the
// callbacks may have changed.
ViewRootImpl impl = decor.getViewRootImpl();
if (impl != null) {
impl.notifyChildRebuilt();
}
}
//如果DecorView尚未添加到WindowManager中,将其添加进去,否则更新Window属性
//Activity启动过程中,第一次resume时,DecorView还尚未添加至WindowManager,所以会走进上面这个case
//由于我们之前将DecorView的Visibility设置成了INVISIBLE,所以此时界面还是不可见
if (a.mVisibleFromClient) {
if (!a.mWindowAdded) {
a.mWindowAdded = true;
wm.addView(decor, l);
} else {
// The activity will get a callback for this {@link LayoutParams} change
// earlier. However, at that time the decor will not be set (this is set
// in this method), so no action will be taken. This call ensures the
// callback occurs with the decor set.
a.onWindowAttributesChanged(l);
}
}

// If the window has already been added, but during resume
// we started another activity, then don't yet make the
// window visible.
} else if (!willBeVisible) {
r.hideForNow = true;
}

// Get rid of anything left hanging around.
//清除遗留的东西
cleanUpPendingRemoveWindows(r, false /* force */);

// The window is now visible if it has been added, we are not
// simply finishing, and we are not starting another activity.
if (!r.activity.mFinished && willBeVisible && r.activity.mDecor != null && !r.hideForNow) {
//分发Configuration更新事件
if (r.newConfig != null) {
performConfigurationChangedForActivity(r, r.newConfig);
r.newConfig = null;
}
//当DecorView add进WindowManager后,ViewRootImpl被创建
ViewRootImpl impl = r.window.getDecorView().getViewRootImpl();
WindowManager.LayoutParams l = impl != null
? impl.mWindowAttributes : r.window.getAttributes();

... //软键盘相关

r.activity.mVisibleFromServer = true;
mNumVisibleActivities++;
//使DecorView可见
if (r.activity.mVisibleFromClient) {
r.activity.makeVisible();
}
}

//当空闲时,检查处理其他后台Activity状态
//对处在stopping或finishing的Activity执行onStop或onDestroy生命周期
r.nextIdle = mNewActivities;
mNewActivities = r;
Looper.myQueue().addIdleHandler(new Idler());
}

这里有三个重要的地方需要注意:

  1. 执行performResumeActivity,这里和之前分析的两个生命周期类似,我们后面再看

  2. ActivitymDecor成员变量赋值,将DecorView添加到WindowManager中,使DecorView可见

  3. 将上一个活动的ActivityClientRecord以链表的形式串在当前ActivityClientRecord后面,向MessageQueue添加一条闲时处理消息Idler,这条消息会遍历ActivityClientRecord的整条nextIdle链,依次检查是否需要stopdestroy Activity,这一点我会在后面关于Activity其他生命周期的文章中再分析

接下来我们简单过一下performResumeActivity

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
public ActivityClientRecord performResumeActivity(IBinder token, boolean finalStateRequest,
String reason) {
final ActivityClientRecord r = mActivities.get(token);

... //状态检查

//为最终生命周期状态
if (finalStateRequest) {
r.hideForNow = false;
r.activity.mStartedActivity = false;
}
try {
r.activity.onStateNotSaved();
//标记Fragments状态为未保存
r.activity.mFragments.noteStateNotSaved();
//更新网络状态
checkAndBlockForNetworkAccess();
if (r.pendingIntents != null) {
deliverNewIntents(r, r.pendingIntents);
r.pendingIntents = null;
}
if (r.pendingResults != null) {
deliverResults(r, r.pendingResults, reason);
r.pendingResults = null;
}
//执行Activity.onResume生命周期
r.activity.performResume(r.startsNotResumed, reason);

//将保存信息的savedInstanceState和persistentState重置为null
r.state = null;
r.persistentState = null;
//设置生命周期状态
r.setState(ON_RESUME);

//回调Activity.onTopResumedActivityChanged,报告栈顶活动Activity发生变化
reportTopResumedActivityChanged(r, r.isTopResumedActivity, "topWhenResuming");
} catch (Exception e) {
...
}
return r;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
final void performResume(boolean followedByPause, String reason) {
//回调ActivityLifecycleCallbacks.onActivityPreResumed
dispatchActivityPreResumed();
//执行onRestart生命周期
//内部会判断当前Activity是否为stop状态,是的话才会真正执行onRestart生命周期
//启动Activity第一次resume时不会进入onRestart生命周期
performRestart(true /* start */, reason);

mFragments.execPendingActions();

mLastNonConfigurationInstances = null;

... //自动填充功能

mCalled = false;
// mResumed is set by the instrumentation
//执行Activity.onResume回调
mInstrumentation.callActivityOnResume(this);
if (!mCalled) {
//必须执行super.onResume方法
throw new SuperNotCalledException(
"Activity " + mComponent.toShortString() +
" did not call through to super.onResume()");
}

// invisible activities must be finished before onResume() completes
... //异常检查

// Now really resume, and install the current status bar and menu.
mCalled = false;

//FragmentManager分发resume状态
mFragments.dispatchResume();
mFragments.execPendingActions();

//执行onPostResume回调
onPostResume();
if (!mCalled) {
//必须要执行super.onPostResume
throw new SuperNotCalledException(
"Activity " + mComponent.toShortString() +
" did not call through to super.onPostResume()");
}
//回调ActivityLifecycleCallbacks.onActivityPostResumed
dispatchActivityPostResumed();
}
1
2
3
4
5
6
7
8
9
10
protected void onResume() {
//回调ActivityLifecycleCallbacks.onActivityResumed
dispatchActivityResumed();
//共享元素动画
mActivityTransitionState.onResume(this);
... //自动填充功能
notifyContentCaptureManagerIfNeeded(CONTENT_CAPTURE_RESUME);

mCalled = true;
}

可以看到,基本上和之前的两个生命周期的执行是一个套路,唯一需要注意的是,在执行onResume生命周期之前,会先检查Activity是否处在stop状态,如果是的话,则会先执行onRestart生命周期,其他地方我在注释上标注的应该已经很明白了,这里就不再多讲了

不要忘了,在TransactionExecutor中还有最后一步ResumeActivityItem.postExecute没做

1
2
3
4
5
6
7
8
9
public void postExecute(ClientTransactionHandler client, IBinder token,
PendingTransactionActions pendingActions) {
try {
// TODO(lifecycler): Use interface callback instead of AMS.
ActivityTaskManager.getService().activityResumed(token);
} catch (RemoteException ex) {
throw ex.rethrowFromSystemServer();
}
}

这里通过Binder又回到了系统进程调用了ATMS.activityResumed方法

1
2
3
4
5
6
7
public final void activityResumed(IBinder token) {
final long origId = Binder.clearCallingIdentity();
synchronized (mGlobalLock) {
ActivityRecord.activityResumedLocked(token);
}
Binder.restoreCallingIdentity(origId);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
static void activityResumedLocked(IBinder token, boolean handleSplashScreenExit) {
final ActivityRecord r = ActivityRecord.forTokenLocked(token);
if (r == null) {
// If an app reports resumed after a long delay, the record on server side might have
// been removed (e.g. destroy timeout), so the token could be null.
return;
}
//SplashScreen
r.setCustomizeSplashScreenExitAnimation(handleSplashScreenExit);
//重置savedState Bundle
r.setSavedState(null /* savedState */);

r.mDisplayContent.handleActivitySizeCompatModeIfNeeded(r);
//防闪烁功能
r.mDisplayContent.mUnknownAppVisibilityController.notifyAppResumedFinished(r);
}

可以看到,最后也就做了一些收尾工作,到这里,整个Activity的启动流程也就圆满结束了

结尾

至此为止,我们Activity启动流程三部连续剧终于是圆满完成了,历时整整半年的时间,我心里压着的这块石头也终于是落地了,后面我应该会再做一些关于Activity其他生命周期变换的分析,比如说Activity是怎样销毁的,欢迎感兴趣的小伙伴点赞、收藏、关注我