Android性能之冷啟動優(yōu)化詳析
1.前言
APP冷啟動比較慢,點(diǎn)擊桌面圖片需要用戶等待很久,體驗較差。
2.APP啟動方式
冷啟動(Cold start)
場景:冷啟動是指APP在手機(jī)啟動后第一次運(yùn)行,或者APP進(jìn)程被kill掉后在再次啟動。
可見冷啟動的必要條件是該APP進(jìn)程不存在,這就意味著系統(tǒng)需要創(chuàng)建進(jìn)程,APP需要初始化。在這三種啟動方式中,冷啟動耗時最長,對于冷啟動的優(yōu)化也是最具挑戰(zhàn)的。因此本文重點(diǎn)談?wù)摰氖菍鋯酉嚓P(guān)的優(yōu)化。
生命周期:Process.start->Application創(chuàng)建->attachBaseContext->onCreate->onStart->onResume->Activity生命周期
啟動速度:在幾種啟動類型中最慢,也是我們優(yōu)化啟動速度最大的攔路虎
溫啟動(Warm start)
場景:App進(jìn)程存在,當(dāng)時Activity可能因為內(nèi)存不足被回收。這時候啟動App不需要重新創(chuàng)建進(jìn)程,但是Activity的onCrate還是需要重新執(zhí)行的。場景類似打開淘寶逛了一圈然后切到微信去聊天去了,過了半小時再次回到淘寶。這時候淘寶的進(jìn)程存在,但是Activity可能被回收,這時候只需要重新加載Activity即可。
生命周期:onCreate->onStart->onResume->Activity生命周期
啟動速度:較快
熱啟動(Hot start)
場景:App進(jìn)程存在,并且Activity對象仍然存在內(nèi)存中沒有被回收。可以重復(fù)避免對象初始化,布局解析繪制。
場景就類似你打開微信聊了一會天這時候出去看了下日歷 在打開微信 微信這時候啟動就屬于熱啟動。
生命周期:onResume->Activity生命周期
啟動速度:快
3.如何統(tǒng)計Android App啟動時間(使用命令行)
adb shell am start -W [packageName]/[packageName.***Activity]
例如:
adb shell am start -W com.dateyou.test/com.datayou.test.ui.home.PageLoadingActivity
當(dāng)然為了結(jié)果更加準(zhǔn)確,可以執(zhí)行多次取平均值。
adb shell am start -S -R 10 -W com.dateyou.test/com.datayou.test.ui.home.PageLoadingActivity
其中-S表示每次啟動前先強(qiáng)行停止,-R表示重復(fù)測試次數(shù)。每一次的輸出如下所示信息。
其中TotalTime代表當(dāng)前Activity啟動時間
4.冷啟動流程
冷啟動指的是應(yīng)用程序從進(jìn)程在系統(tǒng)不存在,到系統(tǒng)創(chuàng)建應(yīng)用運(yùn)行進(jìn)程空間的過程。冷啟動通常會發(fā)生在一下兩種情況:
1)設(shè)備啟動以來首次啟動應(yīng)用程序
2)系統(tǒng)殺死應(yīng)用程序之后再次啟動應(yīng)用程序
在冷啟動的最開始,系統(tǒng)需要負(fù)責(zé)做三件事:
1)加載以及啟動app
2)app啟動之后立刻顯示一個空白的預(yù)覽窗口
3)創(chuàng)建app進(jìn)程
一旦系統(tǒng)完成創(chuàng)建app進(jìn)程后,app進(jìn)程將要接著負(fù)責(zé)完成下面的工作:
1)創(chuàng)建Application對象
2)創(chuàng)建并且啟動主線程ActivityThread
3)創(chuàng)建啟動第一個Activity
4)Inflating views
5)布局屏幕
6)執(zhí)行第一次繪制
一旦app進(jìn)程完完成了第一次繪制工作,系統(tǒng)進(jìn)程就會用main activity替換前面顯示的預(yù)覽窗口,這個時候,用戶就可以正式開始與app進(jìn)行交互了。
從冷啟動的流程看,我們無法干預(yù)app進(jìn)程創(chuàng)建等系統(tǒng)操作,我們能夠干預(yù)的有:
1)預(yù)覽窗口
2)Application生命周期回調(diào)
3)Activity生命周期回調(diào)
5.冷啟動優(yōu)化
1)預(yù)覽窗口
為什么啟動時會出現(xiàn)短暫黑屏或白屏的現(xiàn)象?當(dāng)用戶點(diǎn)擊你的app那一刻到系統(tǒng)調(diào)用Activity.onCreate()之間的這個時間段內(nèi),WindowManager會先加載app主題樣式中的windowBackground做為app的預(yù)覽元素,然后再真正去加載activity的layout布局。
很顯然,如果你的application或activity啟動的過程太慢,導(dǎo)致系統(tǒng)的BackgroundWindow沒有及時被替換,就會出現(xiàn)啟動時白屏或黑屏的情況(取決于你的主題是Dark還是Light)。
解決辦法:在style中自定義一個主題,在其中放一張背景圖片或者廣告頁,讓用戶先看默認(rèn)圖。
2)Application OnCrate()優(yōu)化
1.耗時操作子線程中進(jìn)行
2.非必要初始化懶加載
3)Activity onCreate()優(yōu)化
1.耗時操作子線程中進(jìn)行
2.布局層次減少
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
android studio 使用Mocklocation虛擬定位
這篇文章主要介紹了android studio 使用Mocklocation虛擬定位總結(jié),本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12Android中EditText的drawableRight屬性設(shè)置點(diǎn)擊事件
這篇文章主要介紹了Android中EditText的drawableRight屬性的圖片設(shè)置點(diǎn)擊事件,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10Android多線程斷點(diǎn)續(xù)傳下載功能實現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了Android多線程斷點(diǎn)續(xù)傳下載功能的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03Android布局耗時監(jiān)測的三種實現(xiàn)方式
在Android應(yīng)用開發(fā)中,性能優(yōu)化是一個至關(guān)重要的方面,為了更好地監(jiān)測布局渲染的耗時,我們需要一種可靠的實現(xiàn)方案,本文將介紹三種針對Android布局耗時監(jiān)測的實現(xiàn)方案,幫助開發(fā)者及時發(fā)現(xiàn)并解決布局性能問題,需要的朋友可以參考下2024-03-03