成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

通過實例解析android Activity啟動過程

瀏覽:2日期:2022-09-22 13:17:01

注:只是說明啟動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.0packagesappsLauncher2srccomandroidlauncher2

當點擊一個應用圖標時會執行一連串流程

-》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);

到這里直接跳轉到第一個問題上來了(直接分析第一個就可以解決第二個)

第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

第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的交互以后再補充)

第1種方式--ActivityA啟動ActivityB為例

從startActivity()開始分析。

簡單流程(有時間完整過一遍源碼)

Activity.startActivityActivity.startActivityForResultInstrumentation.execStartActivityActivityManagerProxy.startActivityActivityManagerService.startActivityActivityStack.startActivityMayWaitActivityStack.startActivityLockedActivityStack.startActivityUncheckedLockedActivityStack.resumeTopActivityLockedActivityStack.startPausingLockedApplicationThreadProxy.schedulePauseActivityApplicationThread.schedulePauseActivityActivityThread.queueOrSendMessageH.handleMessageActivityThread.handlePauseActivityActivityManagerProxy.activityPausedActivityManagerService.activityPausedActivityStack.activityPausedActivityStack.completePauseLockedActivityStack.resumeTopActivityLokcedActivityStack.startSpecificActivityLockedActivityStack.realStartActivityLockedApplicationThreadProxy.scheduleLaunchActivityApplicationThread.scheduleLaunchActivityActivityThread.queueOrSendMessageH.handleMessageActivityThread.handleLaunchActivityActivityThread.performLaunchActivityAcitiviyB.onCreate

要查看ActivityManagerNative.java,ActivityManagerProxy.java,ActivityManagerService,還有binder關系看一張圖就可以了

通過實例解析android Activity啟動過程

從圖中可以看出代理類:使用ActivityManagerProxy代理類,來代理ActivityManagerNative類的子類ActivityManagerService;

所以執行請求都是傳遞到ActivityManagerService進行處理

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
主站蜘蛛池模板: 日韩 欧美 自拍 在线 视频 | 全免费a级毛片免费看视频免 | 欧美日本亚洲国产一区二区 | 免费一级欧美片片线观看 | 日本一级高清不卡视频在线 | 韩国美女高清爽快一级毛片 | 亚洲欧美专区精品久久 | 精品国产三级v | 久久久精品久久久久三级 | 精品久久久久久国产91 | 免费视频男女 | 国产精品久久久久久久久久久不卡 | 亚洲精品影院一区二区 | 在线观看国产精品入口 | 99秒拍福利大尺度视频 | 精品手机在线视频 | 国产人成在线视频 | 日本精品一区二区三区在线 | 黄大片日本一级在线a | 日本免费视频观看在线播放 | 经典香港a毛片免费观看 | 鲁一鲁色一色 | 高清一区二区三区四区五区 | 亚洲国产一区在线 | 欧美一级艳片视频免费观看 | 日韩欧美视频一区二区 | 九九久久精品国产 | 亚洲一区二区三区一品精 | 国产r67194吃奶视频 | 看一级特黄a大片日本片 | 国产精品视频第一区二区三区 | 日韩欧美中文字幕在线观看 | 欧美一做特黄毛片 | 996久久国产精品线观看 | 精品国产乱码久久久久久一区二区 | 99久久久久国产 | 亚洲影院国产 | 精品欧美一区二区在线看片 | 亚洲人成片在线观看 | 99视频在线精品自拍 | 欧美综合自拍亚洲综合 |