注:只是說明啟動activity的過程(ActivityThread如何與ActivityManagerService簡稱AmS進行進程間通信調用全過程),不解析android從zygote(受精卵)到整個系統服務的啟動
具體來講,啟動activity的方式有以下幾種:
- 在應用程序中startActivity()或startActivityForResult()方法啟動指定activity
- 在HOME(桌面)程序中單擊應用圖標,啟動新的activity
- 按"BACK"鍵結束當前activity,自動啟動上一個activity
- 長按“Home”鍵,顯示出當前任務列表,從中選擇一個啟動。
先分析第2種方式
android的HOMe桌面程序(launcher)是android系統啟動的第一個應用程序,其他的應用程序安裝后,會在launcher上創建一個快捷圖標,我們點擊桌面上的快捷圖標就會啟動相應的app
桌面程序Launcher.java(源碼基於4.2.2,我沒有下載4.2.2,參考網上源碼)
在android4.0\packages\apps\Launcher2\src\com\android\launcher2
當點擊一個應用圖標時會執行一連串流程
-》Launcher.onClick(View v)單擊app圖標
-》Launcher.startActivitySafely(v, intent, tag)這里比4.0多的一個參數,可能性能優化吧
-》Launcher.startActivity(v, intent, tag)
-》Activity.startActivity(intent, opts.toBundle())
-》Activity.startActivityForResult(intent, -1, options);
到這里直接跳轉到第一個問題上來了(直接分析第一個就可以解決第二個)分析點擊android桌面app圖標啟動應用程序的過程
第4種方式---長按“Home”鍵,顯示出當前任務列表,從中選擇一個啟動
流程:
public static final int KEYCODE_HOME = 3;
PhoneWindowManager.interceptKeyBeforeDispatching()處理長按home事件
showRecentAppsDialog();//彈出近期任務的對話框
RecentApplicationsDialog.onclick.getContext().startActivity(intent);//到這里流程就相同了
這個調用的其實也是第1種的startActivity()。所以1,2,4可以用相同處理流程解析,在后面接紹第1中方式處理流程-----fly
android長按home鍵源碼分析以及模擬長按home事件--彈出近期任務
第3種方式(原理與第1種大致相同)
假設一個app,ActivityA啟動ActivityB,然后ActivityB按下"BACK"鍵其實執行的是activity的finish()方法
簡單流程:
ActivityB.finish()
Activity.finish()
ActivityManagerNative.getDefault().finishActivity()
ActivityManagerService.finishActivity()
ActivityStack.requestFinishActivityLocked()
ActivityStack.finishActivityLocked()
ActivityStack.startPausingLocked()
ActivityB向AmS發送finish()請求
// If the activity is PAUSING, we will complete the finish once
// it is done pausing; else we can just directly finish it here.
上面解釋。AmS會先會在ActivityStack.finishActivityLocked()方法中檢查我們要finish的activity的狀態是否處於pause狀態,如果是將直接執行finish操作,否則,必須先執行startPausingLocked()---這里終點是resume恢復上一個ActivityA,將A顯示在前台窗口
IApplicationThread.schedulePauseActivity()
ActivityThread.schedulePauseActivity()
ActivityThread.sendMessage()
ActivityThread.H.sendMessage()
ActivityThread.H.handleMessage()
ActivityThread.handlePauseActivity()
ActivityThread.performPauseActivity()
Instrumentation.callActivityOnPause()
Activity.performPause()
Activity.onPause()
ActivityManagerNative.getDefault().activityPaused()
ActivityManagerService.activityPaused()
ActivityStack.activityPausedLocked()
ActivityStack.completePauseLocked()
接上面,AmS通知當前ActivityB進入Paused狀態,當ActivityB進入paused狀態后即Activity.onPause()方法執行完后,通知AmS我已經執行完pause操作。於是AmS就准備要在ActivityB所在的進程和任務中恢復ActivityA了;
ActivityStack.resumeTopActivityLocked()
ActivityStack.resumeTopInnerLocked()
IApplicationThread.scheduleResumeActivity()
ActivityThread.scheduleResumeActivity()
ActivityThread.sendMessage()
ActivityTherad.H.sendMessage()
ActivityThread.H.handleMessage()
ActivityThread.H.handleResumeActivity()
Activity.performResume()
Activity.performRestart()
Instrumentation.callActivityOnRestart()
Activity.onRestart()
Activity.performStart()
Instrumentation.callActivityOnStart()
Activity.onStart()
Instrumentation.callActivityOnResume()
Activity.onResume()
到這里activityA已經啟動起來了,但是ActivityB還沒有被finish掉,在ActivityThread.H.handleResumeActivity中會
調用Looper.myQueue().addIdleHandler(new Idler()) 這個方法實現ActivityB的最終銷毀操作
Looper.myQueue().addIdleHandler(new Idler()) ActivityManagerNative.getDefault().activityIdle() ActivityManagerService.activityIdle() ActivityStackSupervisor.activityIdleInternalLocked() ActivityStack.destroyActivityLocked() IApplicationThread.scheduleDestoryActivity() ActivityThread.scheduleDestoryActivity() ActivityThread.sendMessage() ActivityThread.H.sendMessage() ActivityThread.H.handleMessage() ActivityThread.handleDestoryActivity() ActivityThread.performDestoryActivity() Activity.performStop() Instrumentation.callActivityOnStop() Activity.onStop() Instrumentation.callActivityOnDestory() Activity.performDestory() Acitivity.onDestory() ActivityManagerNative.getDefault().activityDestoryed() ActivityManagerService.activityDestoryed() ActivityStack.activityDestoryedLocked()
這就是finish()的全部流程了(具體與WindowsManagerService的交互以后再補充)
具體細節請fly------ Android源碼解析之(十五)-->Activity銷毀流程
第1種方式--ActivityA啟動ActivityB為例
從startActivity()開始分析。
簡單流程(有時間完整過一遍源碼)
1 Activity.startActivity 2 Activity.startActivityForResult 3 Instrumentation.execStartActivity 4 ActivityManagerProxy.startActivity 5 ActivityManagerService.startActivity 6 ActivityStack.startActivityMayWait 7 ActivityStack.startActivityLocked 8 ActivityStack.startActivityUncheckedLocked 9 ActivityStack.resumeTopActivityLocked 10 ActivityStack.startPausingLocked 11 ApplicationThreadProxy.schedulePauseActivity 12 ApplicationThread.schedulePauseActivity 13 ActivityThread.queueOrSendMessage 14 H.handleMessage 15 ActivityThread.handlePauseActivity 16 ActivityManagerProxy.activityPaused 17 ActivityManagerService.activityPaused 18 ActivityStack.activityPaused 19 ActivityStack.completePauseLocked 20 ActivityStack.resumeTopActivityLokced 21 ActivityStack.startSpecificActivityLocked 22 ActivityStack.realStartActivityLocked 23 ApplicationThreadProxy.scheduleLaunchActivity 24 ApplicationThread.scheduleLaunchActivity 25 ActivityThread.queueOrSendMessage 26 H.handleMessage 27 ActivityThread.handleLaunchActivity 28 ActivityThread.performLaunchActivity 29 AcitiviyB.onCreate
Android應用程序內部啟動Activity過程(startActivity)的源代碼分析
要查看ActivityManagerNative.java,ActivityManagerProxy.java,ActivityManagerService,還有binder關系看一張圖就可以了
從圖中可以看出代理類:使用ActivityManagerProxy代理類,來代理ActivityManagerNative類的子類ActivityManagerService;
所以執行請求都是傳遞到ActivityManagerService進行處理