91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

分析Android開機啟動速度優(yōu)化(含應用程序優(yōu)化)

如意 ? 來源:CSDN ? 作者:Peter盼 ? 2020-06-20 10:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

眾所周知Android開機啟動速度較慢,于是如何加快啟動速度便成為一個值得討論的問題。

在查閱過許多資料后(特別是Google Group的android-platform),我整理總結出下面幾點基本看法。

Android開機啟動耗時較多的部分有2個,分別是preload classes和scan packages。

這里又數(shù)preload classes最為耗時,在我的機子上一般需要13秒左右。實際上,在看過google group眾多關于preload class的主題后,基本可以確定以下事實:

preloaded-classes list中預加載的類位于dalvik zygote進程的heap中。在zygote衍生一個新的dalvik進程后,新進程只需加載heap中沒有預加載的類(這些后加載進來的類成為該進程所private獨有的),這樣便加快了應用程序的啟動速度。實際上這是一種以空間換時間的辦法,因為幾乎沒有一個應用程序能夠使用到所有的預加載類,必定有很多類對于該應用程序來說是冗余的。但是也正如Google所說,智能手機開機遠沒有啟動應用程序頻繁——用戶開機一次,但直到下次再開機之前可能要運行多個應用程序。因此犧牲一點啟動時間來換取應用程序加載時的較快速度是合算的。

preloaded-classes list已經(jīng)是Google Android工程師使用眾多測試工具分析,加以手動微調(diào)后形成的最優(yōu)化預加載列表,涵蓋了智能機上最長見的應用類型所需要的各種類。很難想象我們自己能夠有什么手段能夠獲得比這樣更優(yōu)的一個預加載列表。所以,除非你的Android系統(tǒng)是被移植到非智能手機設備上使用(例如MID、EBOOK,可以不需要Telephony相關的類),不建議去“優(yōu)化”preloaded-classes list。

在zygote中單起一個線程來做preload,是否可行?答案是否定的。首先在zygote中不可以新開線程,其次,就算新開一個線程,在目前智能機硬件條件下(單核CPU),除非有頻繁大量的存儲IO,否則我們不能看到我們期望加速啟動效果。

關于scan packages的問題。同樣參考上面提到的那篇帖子,我們從中可以知道一個事實:越少的apk安裝,越短的啟動時間。事實上確實如此,apk安裝的多少的確影響開機速度,但相比而言,scan packages所花費的時間遠沒有preload classe多。似乎這里沒有多少油水可榨,但起碼我們知道了:盡量減少產(chǎn)品中預置的apk數(shù)量可以提升啟動速度(哪怕精簡到極致也許只節(jié)省了2s)。

最后,關于那篇帖子中提到的start services階段,我認為雖然此階段確實需要消耗可觀的時間,但是正如文中提到的那樣,優(yōu)化這些services其實就是剔除我們不需要的一些services,而且不僅僅是修改SystemServer.java的問題,任何使用到被優(yōu)化剔除掉的服務的代碼都必須加以修改,否則系統(tǒng)肯定是起不來的。這樣工作量大,而且難度也不小,并且有一定風險。因此對這些services的優(yōu)化要慎之又慎。

那么加快啟動速度是不是就沒有辦法了呢?也不是。除了硬件上的改動,在軟件上使用BLCR技術也可以解決這個問題。

在此我認為同時有必要提一下應用程序啟動速度加速的問題。用過Android的都會發(fā)現(xiàn),第一次啟動某個應用程序時比較慢,但只要不關機重啟,大部分情況下以后再次啟動就明顯的要快許多。因此我們很容易想到一種辦法,即“預加載”我們的應用程序一次,那么下次用戶再次啟動我們時不就快了嗎?

我們首先明確一點:任何“預加載”的想法都是不切實際的。先不討論實施在技術上的可能性,我們只要看一下Android的Activity生命周期管理就應該明白,就算你通過某種方式“預加載”了你的某個Activity,你也不能確保在用戶真正要求開始運行它的時候,你所“預加載”的Activity還存在,因為Android很可能在你為“預加載”第一次啟動Activity后的不久就將它gc掉了。依靠一個不可靠的技術,顯然是不明智的。

那么還有沒有別的辦法呢?答案是有的,但是只在少數(shù)情況下才有一定意義。在源碼的frameworks/base/core/res/res/values/arrays.xml中,我們可以看到有名為“preloaded_drawables”的項,其中列出的是Android在啟動時預加載的圖形資源,這樣在某個應用程序需要這些圖形資源時就不必再加載了。如果我們某個應用程序包含大量的圖形資源,那么我們可以將其加入到這個preloaded_drawables項中以加快我們應用程序的啟動速度。但是這樣有一個顯而易見的弊端:同preload classes一樣,不是每個應用程序都需要所有預加載的圖形資源,這些冗余的資源反而占據(jù)了應用程序進程的內(nèi)存空間。因此,這種技術實際應用的局限性較大,僅限于這樣一種情況:某個設備只運行固定的幾個應用程序,而且這些應用程序包含大量的圖形資源需要加載。但這樣會是一個什么設備呢?

好了,到此基本上把我這兩天研究的心得寫出來了。限于認識水平有限,如果文中有誤或者哪位能有更好的想法,歡迎在下面留言:)如果以后我又有心得,會再更新此文。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Android
    +關注

    關注

    12

    文章

    4023

    瀏覽量

    133957
  • 啟動速度
    +關注

    關注

    0

    文章

    2

    瀏覽量

    6661
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    API數(shù)據(jù)分析:淘寶流量來源分析,渠道優(yōu)化!

    ? 在電商領域,流量來源分析優(yōu)化營銷策略的核心。淘寶作為中國領先的電商平臺,其流量數(shù)據(jù)可通過API(應用程序接口)高效獲取和分析。本技術帖將逐步指導您如何利用淘寶API進行流量來源
    的頭像 發(fā)表于 01-23 13:42 ?167次閱讀
    API數(shù)據(jù)<b class='flag-5'>分析</b>:淘寶流量來源<b class='flag-5'>分析</b>,渠道<b class='flag-5'>優(yōu)化</b>!

    LDO性能優(yōu)化的應用技巧

    本文圍繞LDO性能優(yōu)化的關鍵環(huán)節(jié)展開,系統(tǒng)闡述了從啟動過程控制、不同負載條件下穩(wěn)定工作到瞬態(tài)響應提升的全鏈路應用技巧。內(nèi)容涵蓋啟動過沖抑制、電子負載在CC/CR模式下的適應性優(yōu)化、
    的頭像 發(fā)表于 01-22 10:24 ?4529次閱讀
    LDO性能<b class='flag-5'>優(yōu)化</b>的應用技巧

    單片機大神的程序優(yōu)化流程

    程序結構優(yōu)化 1、程序的書寫結構 雖然書寫格式并不會影響生成的代碼質量,但是在實際編寫程序時還是應該遵循一定的書寫規(guī)則,一個書寫清晰、明了的程序
    發(fā)表于 12-25 07:38

    Linux系統(tǒng)冗余設計裁剪開機時間優(yōu)化

    1、在保留現(xiàn)有功能(RT-Linux實時特性、SPI驅動正常工作、網(wǎng)口通信正常、USB驅動)的前提下,將Upboard開發(fā)板的Linux系統(tǒng)開機時間從當前~60秒優(yōu)化至≤20秒(上電啟動至系統(tǒng)完全
    發(fā)表于 12-16 22:17

    請問Keil的優(yōu)化等級到底該如何選擇?

    在Keil MDK(Microcontroller Development Kit)中,優(yōu)化等級是編譯器的核心設置之一,它直接影響生成代碼的大小、執(zhí)行速度和調(diào)試便利性。選擇合適的優(yōu)化等級是平衡性
    發(fā)表于 11-20 07:51

    程序運行速度很慢如何優(yōu)化?

    ;gt;外設,內(nèi)存<->內(nèi)存)交給DMA,釋放CPU資源。 優(yōu)化算法: 選擇時間復雜度更低的算法。避免不必要的循環(huán)和重復計算。 減少函數(shù)調(diào)用開銷: 對于頻繁調(diào)用的小函數(shù)
    發(fā)表于 11-17 06:12

    蜂鳥E203內(nèi)核優(yōu)化方法

    提高程序的響應速度和并行度。 應用程序優(yōu)化:針對具體的應用場景,優(yōu)化算法和程序實現(xiàn),減少資源占用
    發(fā)表于 10-21 07:55

    ElfBoard技術貼|【RK3588】ELF 2開發(fā)板開機啟動詳解

    在嵌入式系統(tǒng)開發(fā)中,合理管理開機啟動項目能夠優(yōu)化系統(tǒng)啟動流程,確保關鍵服務和應用按時加載運行。本文將詳細介紹在ELF2開發(fā)板Linux5.10.209系統(tǒng)下基于SystemVinit
    的頭像 發(fā)表于 06-27 16:20 ?2029次閱讀
    ElfBoard技術貼|【RK3588】ELF 2開發(fā)板<b class='flag-5'>開機</b>自<b class='flag-5'>啟動</b>詳解

    鴻蒙5開發(fā)寶藏案例分享---冷啟動優(yōu)化案例分享

    鴻蒙冷啟動優(yōu)化大揭秘!這些官方寶藏案例讓我效率翻倍 ? 大家好呀!最近在優(yōu)化鴻蒙應用時,我偶然發(fā)現(xiàn)了官方文檔里隱藏的性能優(yōu)化寶藏案例。這些實戰(zhàn)經(jīng)驗讓我的應用
    發(fā)表于 06-12 17:22

    VirtualLab:光柵的優(yōu)化分析

    光柵是光學工程師使用的最基本的工具。為了設計和分析這類組件,快速物理光學建模和設計軟件VirtualLab Fusion為用戶提供了許多有用的工具。其中包括參數(shù)優(yōu)化,以輕松優(yōu)化系統(tǒng),以及參數(shù)運行,它
    發(fā)表于 05-23 08:49

    VirtualLab 應用:傾斜光柵的參數(shù)優(yōu)化及公差分析

    允許為目標值定義參數(shù)約束和權重值。更多信息請參見: 參數(shù)優(yōu)化文檔的介紹 第一級次的參數(shù)優(yōu)化 **結果——公差分析 **
    發(fā)表于 05-22 08:52

    HarmonyOS優(yōu)化應用內(nèi)存占用問題性能優(yōu)化

    應用開發(fā)過程中注重內(nèi)存管理,積極采取措施來減少內(nèi)存占用,以優(yōu)化應用程序的性能和用戶體驗。 HarmonyOS提供了一些內(nèi)存管理的工具和接口,幫助開發(fā)者有效地管理內(nèi)存資源: onMemoryLevel接口
    發(fā)表于 05-21 11:27

    HarmonyOS優(yōu)化應用包體積大小問題性能優(yōu)化

    大小之前,需要先了解HarmonyOS應用的應用程序包結構。在進行應用程序包大小優(yōu)化分析時,可以使用掃描工具掃描分析App包,根據(jù)輸出的檢測報告,采取相應措施
    發(fā)表于 05-20 14:50

    系統(tǒng)啟動時間優(yōu)化方案--基于米爾MYD-YG2LX開發(fā)板

    的整體表現(xiàn)。然而,如果驅動程序的行為不良,例如出現(xiàn)崩潰、卡頓或沖突等問題,那么進行優(yōu)化就會變得更加棘手和挑戰(zhàn)。這需要深入分析和修復驅動程序的問題,調(diào)整其代碼和算法,以使其更加高效和可靠
    發(fā)表于 05-09 18:03

    基于RV1126開發(fā)板設置應用開機啟動

    用戶根據(jù)對自身項目程序的管理需求,進行自帶或者自定義應用開機啟動的創(chuàng)建與編輯。
    的頭像 發(fā)表于 04-17 13:49 ?1150次閱讀
    基于RV1126開發(fā)板設置應用<b class='flag-5'>開機</b>自<b class='flag-5'>啟動</b>