ActivityManagerService-B Activity状态改变

版权说明:本文为 开开向前冲 原创文章,转载请注明出处;
注:限于作者水平有限,文中有不对的地方还请指教

很多大神都讲解过AMS是如何管理Activity,我也通过看他们的博客学习了很多,大多数文章通过讲解Activity 的启动过程来说明这个过程,本文根据以ActivityState的切换为主线来说明AMS 是如何管理Activity;

ActivityState
ActivityState.jpg
------> frameworks\base\services\core\java\com\android\server\am\ActivityStack.java
    enum ActivityState {
        INITIALIZING,
        RESUMED,
        PAUSING,
        PAUSED,
        STOPPING,
        STOPPED,
        FINISHING,
        DESTROYING,
        DESTROYED
    }

Activity在生命周期内肯定处于上述状态中的一种;Activity 状态的切换也是AMS管理Activity的一个体现;

1. 初始状态 INITIALIZING

Activity 最初始的状态就是 INITIALIZING,INITIALIZING 字面值代表初始化,那 ActivityRecord 会在什么时候被初始化呢?初始化一般发生在构造这个对象的时候,进入ActivityRecord 的构造方法,有如下:

    ActivityRecord(......) {
        ......
        state = ActivityState.INITIALIZING; //初始化状态
        ......
    }

ActivityRecord 的state对象代表着ActivityRecord的各种状态;现在的问题变成ActivityRecord在什么时候会被初始化呢?看过startActivity流程源码的应该都知道ActivityRecord会在ActivityStackSupervisor的startActivityLocked方法中被初始化;

------> ActivityStackSupervisor.java
   final int startActivityLocked(IApplicationThread caller,
            Intent intent, String resolvedType, ActivityInfo aInfo,
            IVoiceInteractionSession voiceSession, IVoiceInteractor voiceInteractor,
            IBinder resultTo, String resultWho, int requestCode,
            int callingPid, int callingUid, String callingPackage,
            int realCallingPid, int realCallingUid, int startFlags, Bundle options,
            boolean componentSpecified, ActivityRecord[] outActivity, ActivityContainer container,
            TaskRecord inTask) {
        ......
                ActivityRecord r = new ActivityRecord(mService, callerApp, callingUid, callingPackage,
                intent, resolvedType, aInfo, mService.mConfiguration, resultRecord, resultWho,
                requestCode, componentSpecified, this, container, options);
        ......
    }

跟踪startActivityLocked的调用栈就知道它的源头是在ContextImpl.java的startActivity,即平时启动Activity时调用的startActivity()方法;即 ActivityRecord会在startActivity过程中被初始化;这很符合逻辑,不管以什么方式打开应用Activity,都会走到 startActivityLocked,这里会初始化一个ActivityRecord 对象代表新启动的Activity,AMS 通过管理这个ActivityRecord对象来管理Activity的生命周期;

2. 持续状态 RESUMED

RESUMED 状态代表该Activity 处于可见状态,说明AMS已经调整好ActivityRecord的状态,可以向用户显示;RESUMED 是在ActivityStack.java的resumeTopActivityInnerLocked方法中设置:

------> ActivityStack.java
  final boolean resumeTopActivityInnerLocked(ActivityRecord prev, Bundle options) {
    ......
        if (next.app != null && next.app.thread != null) {
            ......
            ActivityState lastState = next.state;
            mService.updateCpuStats();
            if (DEBUG_STATES) Slog.v(TAG, "Moving to RESUMED: " + next + " (in existing)");
            next.state = ActivityState.RESUMED;//设置状态为 RESUMED
            mResumedActivity = next;
            next.task.touchActiveTime();
            mService.addRecentTaskLocked(next.task);
            mService.updateLruProcessLocked(next.app, true, null);
            updateLRUListLocked(next);
            mService.updateOomAdjLocked();
            ......
        }
    ......
  }

resumeTopActivityInnerLocked 方法会在startActivity过程中被调用,该方法会根据需要启动的Activity所在进程是否已经启动执行不同操作;

3. 暂停状态 PAUSING ---> PAUSED

Activity 从可交互状态到不可交互状态需要一个过渡期,这个过渡期就是PAUSING 状态,PAUSING 后Activity会进入PAUSED状态,代表该Activity 处于正在暂停的过程,说明AMS 正在调整Activity 状态,使其不再和用户交互;在启动新Activity的时候,会先暂停目前处于RESUMED状态的Activity,此时会回调两个应用的Lifecycle方法,Lifecycle 方法是AMS 通过回调ActivityThread中ApplicationThread的方法来调用(此时ActivityThread为Server,AMS为Client);


ApplicationThread-schedule.png
------> ActivityStack.java
/**
     * Start pausing the currently resumed activity.  It is an error to call this if there
     * is already an activity being paused or there is no resumed activity.
     *
     * @param userLeaving True if this should result in an onUserLeaving to the current activity.
     * @param uiSleeping True if this is happening with the user interface going to sleep (the
     * screen turning off).
     * @param resuming True if this is being called as part of resuming the top activity, so
     * we shouldn't try to instigate a resume here.
     * @param dontWait True if the caller does not want to wait for the pause to complete.  If
     * set to true, we will immediately complete the pause here before returning.
     * @return Returns true if an activity now is in the PAUSING state, and we are waiting for
     * it to tell us when it is done.
     */
    final boolean startPausingLocked(boolean userLeaving, boolean uiSleeping, boolean resuming,
            boolean dontWait) {
        ActivityRecord prev = mResumedActivity;//将正处于RESUMED状态的Activity标记为prev(A->B,A的从RESUMED->PAUSING)
        mResumedActivity = null;
        mPausingActivity = prev;//启动新Activity的Activity将处于mPausingActivity状态
        mLastPausedActivity = prev;
        prev.state = ActivityState.PAUSING;//设置状态为PAUSING
        prev.task.touchActiveTime();
        if (prev.app != null && prev.app.thread != null) {
            if (DEBUG_PAUSE) Slog.v(TAG, "Enqueueing pending pause: " + prev);
            try {
            
                prev.app.thread.schedulePauseActivity(prev.appToken, prev.finishing,
                        userLeaving, prev.configChangeFlags, dontWait);//调用Activity LifeCycle的onPause方法
            } 
        } else {
            mPausingActivity = null;
            mLastPausedActivity = null;
            mLastNoHistoryActivity = null;
        }
        if (mPausingActivity != null) {
            if (dontWait) {
                // If the caller said they don't want to wait for the pause, then complete
                // the pause now.
                completePauseLocked(false);//设置Activity状态为PAUSED
                return false;

            } else {
                // Schedule a pause timeout in case the app doesn't respond.
                // We don't give it much time because this directly impacts the
                // responsiveness seen by the user.
                Message msg = mHandler.obtainMessage(PAUSE_TIMEOUT_MSG);
                msg.obj = prev;
                prev.pauseTime = SystemClock.uptimeMillis();
                mHandler.sendMessageDelayed(msg, PAUSE_TIMEOUT);
                return true;
            }

        } else {
            // This activity failed to schedule the
            // pause, so just treat it as being paused now.
            if (DEBUG_PAUSE) Slog.v(TAG, "Activity not running, resuming next.");
            if (!resuming) {
                mStackSupervisor.getFocusedStack().resumeTopActivityLocked(null);//会重新进入设置状态为PAUSED
            }
            return false;
        }
    }

private void completePauseLocked(boolean resumeNext) {
        ActivityRecord prev = mPausingActivity;
        if (prev != null) {
            prev.state = ActivityState.PAUSED; //设置前一个Activity的状态为 PAUSED
            ......
        }
       ......
        // Notfiy when the task stack has changed
        mService.notifyTaskStackChangedLocked();
    }

4. 停止状态 STOPPING ---> STOPPED

STOPPING ---> STOPPED 代表Activity停止的过程和状态;对应过程Activity LifeCycle的onStop() 方法会被回调;

    final void stopActivityLocked(ActivityRecord r) {
        ......
        if (r.app != null && r.app.thread != null) {
            adjustFocusedActivityLocked(r, "stopActivity");
            r.resumeKeyDispatchingLocked();
            try {
                r.stopped = false;
                if (DEBUG_STATES) Slog.v(TAG, "Moving to STOPPING: " + r
                        + " (stop requested)");
                r.state = ActivityState.STOPPING;//设置前一个Activity 的状态为STOPPING
                Log.d(TAG + "STOPPING", Log.getStackTraceString(new Throwable()));//keiven-chen
                if (!r.visible) {
                    mWindowManager.setAppVisibility(r.appToken, false);
                }
                r.app.thread.scheduleStopActivity(r.appToken, r.visible, r.configChangeFlags);//回调Activity LifeCycle的onStop()方法
                if (mService.isSleepingOrShuttingDown()) {
                    r.setSleeping(true);
                }
                Message msg = mHandler.obtainMessage(STOP_TIMEOUT_MSG, r);
                mHandler.sendMessageDelayed(msg, STOP_TIMEOUT);
            } catch (Exception e) {
                // Maybe just ignore exceptions here...  if the process
                // has crashed, our death notification will clean things
                // up.
                Slog.w(TAG, "Exception thrown during pause", e);
                // Just in case, assume it to be stopped.
                r.stopped = true;
                r.state = ActivityState.STOPPED;
                Log.d(TAG+"STOPPED",Log.getStackTraceString(new Throwable()));//Keiven-chen
            }
        }
    }

final void activityStoppedLocked(ActivityRecord r, Bundle icicle,
            PersistableBundle persistentState, CharSequence description) { //通过该方法设置Activity状态为 STOPPED
        ...... 
        if (icicle != null) {
            // If icicle is null, this is happening due to a timeout, so we
            // haven't really saved the state.
            r.icicle = icicle;
            r.haveState = true;
            r.launchCount = 0;
            r.updateThumbnailLocked(null, description);
        }
        if (!r.stopped) {
            if (DEBUG_STATES) Slog.v(TAG, "Moving to STOPPED: " + r + " (stop complete)");
            mHandler.removeMessages(STOP_TIMEOUT_MSG, r);
            r.stopped = true;
            r.state = ActivityState.STOPPED; //设置前一个Activity 的状态为STOPPED
            Log.d(TAG+"STOPPED",Log.getStackTraceString(new Throwable()));//Keiven-chen
            if (mActivityContainer.mActivityDisplay.mVisibleBehindActivity == r) {
                mStackSupervisor.requestVisibleBehindLocked(r, false);
            }
            if (r.finishing) {
                r.clearOptionsLocked();
            } else {
                if (r.configDestroy) {
                    destroyActivityLocked(r, true, "stop-config");
                    mStackSupervisor.resumeTopActivitiesLocked();
                } else {
                    mStackSupervisor.updatePreviousProcessLocked(r);
                }
            }
        }
    }
5. FINISHING, DESTROYING, DESTROYED

Activity 会占用很多系统资源,当Activity 不需要显示的时候需要回收相关资源,这个过程涉及到的三个状态就是 FINISHING, DESTROYING, DESTROYED;
FINISHING 状态在 finishCurrentActivityLocked方法中设置;

final ActivityRecord finishCurrentActivityLocked(ActivityRecord r, int mode, boolean oomAdj) {
            ......
            r.state = ActivityState.STOPPING;//设置Activity 的状态为STOPPING
            Log.d(TAG + "STOPPING",Log.getStackTraceString(new Throwable()));//Keiven-chen
            if (oomAdj) {
                mService.updateOomAdjLocked();
            }
            return r;
        }

        // make sure the record is cleaned out of other places.
        mStackSupervisor.mStoppingActivities.remove(r);
        mStackSupervisor.mGoingToSleepActivities.remove(r);
        mStackSupervisor.mWaitingVisibleActivities.remove(r);
        if (mResumedActivity == r) {
            mResumedActivity = null;
        }
        final ActivityState prevState = r.state;
        r.state = ActivityState.FINISHING; //设置Activity 状态为FINISHING
        Log.d(TAG + "FINISHING",Log.getStackTraceString(new Throwable()));//Keiven-chen

        if (mode == FINISH_IMMEDIATELY
                || prevState == ActivityState.STOPPED
                || prevState == ActivityState.INITIALIZING) {
            // If this activity is already stopped, we can just finish
            // it right now.
            r.makeFinishing();
            boolean activityRemoved = destroyActivityLocked(r, true, "finish-imm");//该方法会销毁Activity,即Activity通过该方法进入 DESTROYING状态;
            if (activityRemoved) {
                mStackSupervisor.resumeTopActivitiesLocked();
            }
            return activityRemoved ? null : r;
        }
        mStackSupervisor.mFinishingActivities.add(r);
        r.resumeKeyDispatchingLocked();
        mStackSupervisor.getFocusedStack().resumeTopActivityLocked(null);
        return r;
    }

Recents中清除应用会调用ProcessRecord的Kil掉进程,Kill进程就会导致进程的Binder死亡,会触发binderDied被调用,该方法会回收每一个Activity 资源,这样Activity就处于DESTROYED状态了,即Activity 处于完全销毁状态;

/**
     * Perform the common clean-up of an activity record.  This is called both
     * as part of destroyActivityLocked() (when destroying the client-side
     * representation) and cleaning things up as a result of its hosting
     * processing going away, in which case there is no remaining client-side
     * state to destroy so only the cleanup here is needed.
     */
    final void cleanUpActivityLocked(ActivityRecord r, boolean cleanServices,
            boolean setState) {
        if (mResumedActivity == r) {
            mResumedActivity = null;
        }
        if (mPausingActivity == r) {
            mPausingActivity = null;
        }
        mService.clearFocusedActivity(r);

        r.configDestroy = false;
        r.frozenBeforeDestroy = false;

        if (setState) {
            r.state = ActivityState.DESTROYED; //设置Activity的状态为DESTROYED
            Log.d(TAG + "DESTROYED",Log.getStackTraceString(new Throwable()));//Keiven-chen
            r.app = null;
        }

        // Make sure this record is no longer in the pending finishes list.
        // This could happen, for example, if we are trimming activities
        // down to the max limit while they are still waiting to finish.
        mStackSupervisor.mFinishingActivities.remove(r);
        mStackSupervisor.mWaitingVisibleActivities.remove(r);

        // Remove any pending results.
        if (r.finishing && r.pendingResults != null) {
            for (WeakReference<PendingIntentRecord> apr : r.pendingResults) {
                PendingIntentRecord rec = apr.get();
                if (rec != null) {
                    mService.cancelIntentSenderLocked(rec, false);
                }
            }
            r.pendingResults = null;
        }

        if (cleanServices) {
            cleanUpActivityServicesLocked(r);
        }

        // Get rid of any pending idle timeouts.
        removeTimeoutsForActivityLocked(r);
        if (getVisibleBehindActivity() == r) {
            mStackSupervisor.requestVisibleBehindLocked(r, false);
        }
    }
Log演示:下面是Activity-A 通过startActivity方法打开Activity-B过程中两个Activity 状态变化过程LOG
11-13 15:54:18.964 2899-3804/system_process I/ActivityManager: START u0 {cmp=test.activitytest/.SecondActivity} from uid 10061 on display 0
11-13 15:54:18.964 2899-3804/system_process D/ActivityManagerINITIALIZING: java.lang.Throwable  //Activity-B 处于INITIALIZING状态
                          at com.android.server.am.ActivityRecord.<init>(ActivityRecord.java:405)
                          at com.android.server.am.ActivityStackSupervisor.startActivityLocked(ActivityStackSupervisor.java:1527)
                          at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:995)
                          at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3497)
                          at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3484)
                          at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
                          at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                          at android.os.Binder.execTransact(Binder.java:446)
11-13 15:54:18.973 2899-3804/system_process D/ActivityManagerPAUSING: java.lang.Throwable  //Activity-A 处于 PAUSING状态
                      at com.android.server.am.ActivityStack.startPausingLocked(ActivityStack.java:827)
                      at com.android.server.am.ActivityStack.resumeTopActivityInnerLocked(ActivityStack.java:1642)
                      at com.android.server.am.ActivityStack.resumeTopActivityLocked(ActivityStack.java:1480)
                      at com.android.server.am.ActivityStackSupervisor.resumeTopActivitiesLocked(ActivityStackSupervisor.java:2518)
                      at com.android.server.am.ActivityStack.startActivityLocked(ActivityStack.java:2127)
                      at com.android.server.am.ActivityStackSupervisor.startActivityUncheckedLocked(ActivityStackSupervisor.java:2258)
                      at com.android.server.am.ActivityStackSupervisor.startActivityLocked(ActivityStackSupervisor.java:1560)
                      at com.android.server.am.ActivityStackSupervisor.startActivityMayWait(ActivityStackSupervisor.java:995)
                      at com.android.server.am.ActivityManagerService.startActivityAsUser(ActivityManagerService.java:3497)
                      at com.android.server.am.ActivityManagerService.startActivity(ActivityManagerService.java:3484)
                      at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:140)
                      at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                      at android.os.Binder.execTransact(Binder.java:446)
11-13 15:54:18.992 2899-4338/system_process D/ActivityManagerPAUSED: java.lang.Throwable //Activity-A 处于 PAUSED状态
                      at com.android.server.am.ActivityStack.completePauseLocked(ActivityStack.java:974)
                      at com.android.server.am.ActivityStack.activityPausedLocked(ActivityStack.java:916)
                      at com.android.server.am.ActivityManagerService.activityPaused(ActivityManagerService.java:6459)
                      at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:513)
                      at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                      at android.os.Binder.execTransact(Binder.java:446)
11-13 15:54:19.003 2899-4338/system_process D/ActivityManagerRESUMED: java.lang.Throwable // Activity-B 处于RESUMED状态
                      at com.android.server.am.ActivityStack.minimalResumeActivityLocked(ActivityStack.java:659)
                      at com.android.server.am.ActivityStackSupervisor.realStartActivityLocked(ActivityStackSupervisor.java:1279)
                      at com.android.server.am.ActivityStackSupervisor.startSpecificActivityLocked(ActivityStackSupervisor.java:1326)
                      at com.android.server.am.ActivityStack.resumeTopActivityInnerLocked(ActivityStack.java:1928)
                      at com.android.server.am.ActivityStack.resumeTopActivityLocked(ActivityStack.java:1480)
                      at com.android.server.am.ActivityStackSupervisor.resumeTopActivitiesLocked(ActivityStackSupervisor.java:2518)
                      at com.android.server.am.ActivityStack.completePauseLocked(ActivityStack.java:1020)
                      at com.android.server.am.ActivityStack.activityPausedLocked(ActivityStack.java:916)
                      at com.android.server.am.ActivityManagerService.activityPaused(ActivityManagerService.java:6459)
                      at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:513)
                      at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                      at android.os.Binder.execTransact(Binder.java:446)
11-13 15:54:19.157 2899-2942/system_process I/ActivityManager: Displayed test.activitytest/.SecondActivity: +165ms
11-13 15:54:19.186 2899-2937/system_process D/ActivityManagerSTOPPING: java.lang.Throwable //Activity-A 处于STOPPING状态
                     at com.android.server.am.ActivityStack.stopActivityLocked(ActivityStack.java:2548)
                     at com.android.server.am.ActivityStackSupervisor.activityIdleInternalLocked(ActivityStackSupervisor.java:2391)
                     at com.android.server.am.ActivityStackSupervisor$ActivityStackSupervisorHandler.activityIdleInternal(ActivityStackSupervisor.java:3586)
                     at com.android.server.am.ActivityStackSupervisor$ActivityStackSupervisorHandler.handleMessage(ActivityStackSupervisor.java:3608)
                     at android.os.Handler.dispatchMessage(Handler.java:102)
                     at android.os.Looper.loop(Looper.java:135)
                     at android.os.HandlerThread.run(HandlerThread.java:61)
                     at com.android.server.ServiceThread.run(ServiceThread.java:46)
11-13 15:54:19.209 2899-4338/system_process D/ActivityManagerSTOPPED: java.lang.Throwable //Activity-A 处于STOPPED状态
                     at com.android.server.am.ActivityStack.activityStoppedLocked(ActivityStack.java:951)
                     at com.android.server.am.ActivityManagerService.activityStopped(ActivityManagerService.java:6480)
                     at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:524)
                     at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                     at android.os.Binder.execTransact(Binder.java:446)

上面是从Activity-A跳转到Activity-B的状态变化调用栈,此时在Activity-B的界面点击Recents,然后清除当前任务栈,此时Activity-A跳转到Activity-B的状态变化调用栈如下:

11-13 16:13:44.658 2899-4434/system_process D/ActivityManagerFINISHING: java.lang.Throwable
                       at com.android.server.am.ActivityStack.finishCurrentActivityLocked(ActivityStack.java:2825)
                       at com.android.server.am.ActivityStack.finishActivityLocked(ActivityStack.java:2775)
                       at com.android.server.am.TaskRecord.performClearTaskAtIndexLocked(TaskRecord.java:613)
                       at com.android.server.am.TaskRecord.removeTaskActivitiesLocked(TaskRecord.java:702)
                        com.android.server.am.ActivityManagerService.removeTaskByIdLocked(ActivityManagerService.java:8627)
                       at com.android.server.am.ActivityManagerService.removeTask(ActivityManagerService.java:8645)
                       at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:1908)
                       at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                       at android.os.Binder.execTransact(Binder.java:446)
11-13 16:13:44.659 2899-4434/system_process D/ActivityManagerDESTROYING: java.lang.Throwable
                        at com.android.server.am.ActivityStack.destroyActivityLocked(ActivityStack.java:3265)
                        at com.android.server.am.ActivityStack.finishCurrentActivityLocked(ActivityStack.java:2833)
                        at com.android.server.am.ActivityStack.finishActivityLocked(ActivityStack.java:2775)
                        at com.android.server.am.TaskRecord.performClearTaskAtIndexLocked(TaskRecord.java:613)
                        at com.android.server.am.TaskRecord.removeTaskActivitiesLocked(TaskRecord.java:702)
                        at com.android.server.am.ActivityManagerService.removeTaskByIdLocked(ActivityManagerService.java:8627)
                        at com.android.server.am.ActivityManagerService.removeTask(ActivityManagerService.java:8645)
                        at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:1908)
                        at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                        at android.os.Binder.execTransact(Binder.java:446)
11-13 16:13:44.661 2899-4434/system_process D/ActivityManagerFINISHING: java.lang.Throwable
                        at com.android.server.am.ActivityStack.finishCurrentActivityLocked(ActivityStack.java:2825)
                        at com.android.server.am.ActivityStack.finishActivityLocked(ActivityStack.java:2775)
                        at com.android.server.am.TaskRecord.performClearTaskAtIndexLocked(TaskRecord.java:613)
                        at com.android.server.am.TaskRecord.removeTaskActivitiesLocked(TaskRecord.java:702)
                        at com.android.server.am.ActivityManagerService.removeTaskByIdLocked(ActivityManagerService.java:8627)
                        at com.android.server.am.ActivityManagerService.removeTask(ActivityManagerService.java:8645)
                        at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:1908)
                        at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                        at android.os.Binder.execTransact(Binder.java:446)
11-13 16:13:44.879 2899-4434/system_process D/ActivityManagerDESTROYING: java.lang.Throwable
                        at com.android.server.am.ActivityStack.destroyActivityLocked(ActivityStack.java:3265)
                        at com.android.server.am.ActivityStack.finishCurrentActivityLocked(ActivityStack.java:2833)
                        at com.android.server.am.ActivityStack.finishActivityLocked(ActivityStack.java:2775)
                        at com.android.server.am.TaskRecord.performClearTaskAtIndexLocked(TaskRecord.java:613)
                        at com.android.server.am.TaskRecord.removeTaskActivitiesLocked(TaskRecord.java:702)
                        at com.android.server.am.ActivityManagerService.removeTaskByIdLocked(ActivityManagerService.java:8627)
                        at com.android.server.am.ActivityManagerService.removeTask(ActivityManagerService.java:8645)
                        at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:1908)
                        at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                        at android.os.Binder.execTransact(Binder.java:446)
11-13 16:13:44.879 2899-4434/system_process D/ActivityManagerKill: java.lang.Throwable//Kill 进程,释放资源
                        at com.android.server.am.ProcessRecord.kill(ProcessRecord.java:530)
                        at com.android.server.am.ActivityManagerService.cleanUpRemovedTaskLocked(ActivityManagerService.java:8569)
                        at com.android.server.am.ActivityManagerService.removeTaskByIdLocked(ActivityManagerService.java:8628)
                        at com.android.server.am.ActivityManagerService.removeTask(ActivityManagerService.java:8645)
                        at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:1908)
                        at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2253)
                        at android.os.Binder.execTransact(Binder.java:446)
11-13 16:13:44.997 2899-4436/system_process D/ActivityManagerDESTROYED: java.lang.Throwable
                        at com.android.server.am.ActivityStack.removeActivityFromHistoryLocked(ActivityStack.java:3066)
                        at com.android.server.am.ActivityStack.removeHistoryRecordsForAppLocked(ActivityStack.java:3446)
                        at com.android.server.am.ActivityStack.handleAppDiedLocked(ActivityStack.java:3994)
                        at com.android.server.am.ActivityStackSupervisor.handleAppDiedLocked(ActivityStackSupervisor.java:2435)
                        at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:4698)
                        at com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:4850)
                        at com.android.server.am.ActivityManagerService$AppDeathRecipient.binderDied(ActivityManagerService.java:1228)
                        at android.os.BinderProxy.sendDeathNotice(Binder.java:551)
11-13 16:14:00.198 2899-4436/system_process D/ActivityManagerDESTROYED: java.lang.Throwable
                        at com.android.server.am.ActivityStack.cleanUpActivityLocked(ActivityStack.java:3012)
                        at com.android.server.am.ActivityStack.removeHistoryRecordsForAppLocked(ActivityStack.java:3467)
                        at com.android.server.am.ActivityStack.handleAppDiedLocked(ActivityStack.java:3994)
                        at com.android.server.am.ActivityStackSupervisor.handleAppDiedLocked(ActivityStackSupervisor.java:2435)
                        at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:4698)
                        at com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:4850)
                        at com.android.server.am.ActivityManagerService$AppDeathRecipient.binderDied(ActivityManagerService.java:1228)
                        at android.os.BinderProxy.sendDeathNotice(Binder.java:551)
11-13 16:14:00.356 2899-4436/system_process D/ActivityManagerDESTROYED: java.lang.Throwable
                        at com.android.server.am.ActivityStack.removeActivityFromHistoryLocked(ActivityStack.java:3066)
                        at com.android.server.am.ActivityStack.removeHistoryRecordsForAppLocked(ActivityStack.java:3446)
                        at com.android.server.am.ActivityStack.handleAppDiedLocked(ActivityStack.java:3994)
                        at com.android.server.am.ActivityStackSupervisor.handleAppDiedLocked(ActivityStackSupervisor.java:2435)
                        at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:4698)
                        at com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:4850)
                        at com.android.server.am.ActivityManagerService$AppDeathRecipient.binderDied(ActivityManagerService.java:1228)
                        at android.os.BinderProxy.sendDeathNotice(Binder.java:551)
11-13 16:14:00.560 2899-4436/system_process D/ActivityManagerDESTROYED: java.lang.Throwable
                       at com.android.server.am.ActivityStack.cleanUpActivityLocked(ActivityStack.java:3012)
                       at com.android.server.am.ActivityStack.removeHistoryRecordsForAppLocked(ActivityStack.java:3467)
                       at com.android.server.am.ActivityStack.handleAppDiedLocked(ActivityStack.java:3994)
                       at com.android.server.am.ActivityStackSupervisor.handleAppDiedLocked(ActivityStackSupervisor.java:2435)
                       at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:4698)
                       at com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:4850)
                       at com.android.server.am.ActivityManagerService$AppDeathRecipient.binderDied(ActivityManagerService.java:1228)
                       at android.os.BinderProxy.sendDeathNotice(Binder.java:551)

由于我编写的APP 包含两个Activity(Activity-A,Activity-B),所以在Recents中清除该APP时会将两个两个Activity资源回收,所以FINISHING,DESTROYING,DESTROYED 状态都是成双出现;

总结:至此Activity 的各种状态都已经说完,完整的状态切换过程如下(Activity-A —> Activity-B)
RESUMED(A)->INITIALIZING(B)->PAUSING(A)->PAUSED(A)->RESUMED(B)->STOPING(A)->STOPED(A)->FINISHING(A) (正常从A->B 启动情况,这种情况不涉及到Destroy Activity)
RESUMED(A)->INITIALIZING(B)->PAUSING(A)->PAUSED(A)->RESUMED(B)->STOPING(A)->STOPED(A)->FINISHING(A)->DESTROYING(A)->DESTROYED(A)(涉及销毁情况,这里只销毁A,B的销毁过程类似),当Activity 处于RESUMED状态时,我们就可以和该Activity进行交互了;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容