溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android內核開發(fā):為什么刷機后系統(tǒng)第一次啟動會很慢?

發(fā)布時間:2020-06-29 22:53:37 來源:網(wǎng)絡 閱讀:11365 作者:Jhuster 欄目:移動開發(fā)

在做Android內核開發(fā)的過程中,我們會發(fā)現(xiàn),每次編譯完系統(tǒng)源碼,燒錄到設備/手機中后,第一次啟動都會很慢很慢,要好幾分鐘甚至十幾分鐘,為什么會出現(xiàn)這樣的現(xiàn)象呢?系統(tǒng)刷機后第一次啟動與后面再次啟動有什么不同呢?


要解答這個問題,首先我們需要了解一下Android Dalvik虛擬機,以及Dalvik-cache。


由于嵌入式設備內存有限、CPU處理器不夠強大、功耗敏感等原因,Google沒有使用標準的JVM虛擬機,而是為Android單獨開發(fā)了Dalvik虛擬機。


Dalvik虛擬機與JVM虛擬機有很大不同,它運行的是經(jīng)過優(yōu)化和壓縮的DEX字節(jié)碼,與標準的JAR字節(jié)碼并不一樣,占用空間更小,而且還可以進一步優(yōu)化,Android SDK中專門提供了dx工具把傳統(tǒng)的Java字節(jié)碼轉換為Dalvik虛擬機可以運行的DEX字節(jié)碼,這個轉換過程是在程序編譯的時候就完成了,這就是為什么我們可以用Java來編寫能運行于Android Dalvik虛擬機的程序的原因了。關于這個過程,下面這張示意圖比較直觀:


Android內核開發(fā):為什么刷機后系統(tǒng)第一次啟動會很慢?


為了便于傳播,Android SDK將程序編譯后的DEX字節(jié)碼文件、資源文件、lib庫、AndroidManifest.xml等文件一起打包壓縮為apk文件(其實就是一個zip壓縮文件),因此,apk的安裝與卸載其實就是對這個zip壓縮包里面的文件進行解壓分析拷貝和優(yōu)化的過程。


由于DEX字節(jié)碼位于apk壓縮包中,因此,如果程序啟動的時候,每次都要從apk文件中解壓提取DEX字節(jié)碼,明顯效率不高,因此,Android系統(tǒng)設計了如下策略:


(1) 創(chuàng)建一個"dalvik-cache"文件夾,專門存放DEX字節(jié)碼,具體位于/data/dalvik-cache


(2) 系統(tǒng)第一次啟動時,掃描所有的預裝apk文件,提取程序的DEX字節(jié)碼,經(jīng)過優(yōu)化后,存放到dalvik-cache目錄中


(3) 每次安裝新的apk的時候,也同樣提取DEX字節(jié)碼,優(yōu)化后放入dalvik-cache目錄中


(4) 用戶點擊應用圖標后,直接從dalvik-cache目錄中快速加載優(yōu)化過的DEX字節(jié)碼,這樣程序就可以很快的啟動了。


理解了上述原理,本文探討的問題也就迎刃而解了,Android系統(tǒng)刷機后第一次啟動時,需要掃描所有預裝的apk文件,提取dex字節(jié)碼,優(yōu)化并且拷貝到/data/dalvik-cache緩存目錄中,因此,第一次啟動耗時會明顯更高。


擴展閱讀: 《Dalvik Optimization and Verification With dexopt》


關于Android系統(tǒng)刷機后第一次啟動的特點就簡單介紹到這里了,有任何疑問或者建議歡迎留言或者來信lujun.hust@gmail.com交流,或者關注我的新浪微博 @盧_俊 獲取最新的文章和資訊。


向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI