分析:Android系統刷機後,第一次開機啟動很慢的原因

來源:互聯網
上載者:User

標籤:

       在做Android核心開發的過程中,我們會發現,每次編譯完系統源碼,燒錄到裝置/手機中後,第一次啟動都會很慢很慢,要好幾分鐘甚至十幾分鐘,為什麼會出現這樣的現象呢?系統刷機後第一次啟動與後面再次啟動有什麼不同呢?

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

       由於嵌入式裝置記憶體有限、CPU處理器不夠強大、功耗敏感等原因,Google沒有使用標準的JVM虛擬機器,而是為Android單獨開發了Dalvik虛擬機器。

       Dalvik虛擬機器與JVM虛擬機器有很大不同,它啟動並執行是經過最佳化和壓縮的DEX位元組碼,與標準的JAR位元組碼並不一樣,佔用空間更小,而且還可以進一步最佳化,Android SDK中專門提供了dx工具把傳統的Java位元組碼轉換為Dalvik虛擬機器可以啟動並執行DEX位元組碼,這個轉換過程是在程式編譯的時候就完成了,這就是為什麼我們可以用Java來編寫能運行於Android Dalvik虛擬機器的程式的原因了。關於這個過程,下面這張比較直觀:

       為了便於傳播,Android SDK將程式編譯後的DEX位元組碼檔案、資源檔、lib庫、AndroidManifest.xml等檔案一起打包壓縮為apk檔案(其實就是一個 zip壓縮檔),因此,apk的安裝與卸載其實就是對這個zip壓縮包裡面的檔案進行解壓分析拷貝和最佳化的過程。

       由於DEX位元組碼位於apk壓縮包中,因此,如果程式啟動的時候,每次都要從apk檔案中解壓提取DEX位元組碼,明顯效率不高,因此,Android系統設計了如下策略:

       (1) 建立一個"dalvik-cache"檔案夾,專門存放DEX位元組碼,具體位於/data/dalvik-cache

       (2) 系統第一次啟動時,掃描所有的預裝apk檔案,提取程式的DEX位元組碼,經過最佳化後,存放到dalvik-cache目錄中

       (3) 每次安裝新的apk的時候,也同樣提取DEX位元組碼,最佳化後放入dalvik-cache目錄中

       (4) 使用者點擊應用表徵圖後,直接從dalvik-cache目錄中快速載入最佳化過的DEX位元組碼,這樣程式就可以很快的啟動了。

       理解了上述原理,本文探討的問題也就迎刃而解了,Android系統刷機後第一次開機啟動時,需要掃描所有預裝的apk檔案,提取dex位元組碼,最佳化並且拷貝到/data/dalvik-cache緩衝目錄中,因此,第一次啟動耗時會明顯更高。

美文推薦:

  • 技術部落格:針對行動裝置 App加密的問題,如何加密.DEX檔案呢?
  • 技術部落格:安卓APP破解技術有哪些?如何防反編譯
  • 技術部落格:如何防二次打包,愛加密加固APK防破解

分析:Android系統刷機後,第一次開機啟動很慢的原因

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.