一、前言
在閱讀這篇文章之前,首先需要理解幾個東西:
1、什麼是Android的冷啟動時間?
冷啟動時間是指使用者從手機案頭點擊APP的那一刻起到啟動頁面的Activity調用onCreate()方法之間的這個時間段。
2、在冷啟動的時間段內發生了什嗎?
首先我們要知道當開啟一個Activity的時候發生了什麼,在一個Activity開啟時,如果該Activity所屬的Application還沒有啟動,那麼系統會為這個Activity建立一個進程(每建立一個進程都會調用一次Application,所以Application的onCreate()方法可能會被調用多次),在進程的建立和初始化中,勢必會消耗一些時間,在這個時間裡,WindowManager會先載入APP裡的主題樣式裡的視窗背景(windowBackground)作為預覽元素,然後才去真正的載入布局,如果這個時間過長,而預設的背景又是黑色或者白色,這樣會給使用者造成一種錯覺,這個APP很卡,很不流暢,自然也影響了使用者體驗。
來看下效果圖:
未最佳化
最佳化方案1
最佳化方案2
二、消除啟動時的白屏/黑屏
在使用者點擊手機案頭APP的時候,看到的黑屏或者白屏其實是介面渲染前的第一幀,如果你看懂了文章頭的那2個問題,那麼解決這個問題就非常輕鬆了,無非就是將Theme裡的windowBackground設定成我們想要讓使用者看到的畫面就可以了,這裡有2種做法:
1、將背景圖設定成我們APP的Logo圖,作為APP啟動的引導,現在市面上大部分的APP也是這麼做的。
<style name="AppWelcome" parent="AppTheme"> <item name="android:windowBackground">@mipmap/bg_welcome_start</item> </style>
2、將背景顏色設定為透明色,這樣當使用者點擊案頭APP圖片的時候,並不會"立即"進入APP,而且在案頭上停留一會,其實這時候APP已經是啟動的了,只是我們心機的把Theme裡的windowBackground的顏色設定成透明的,強行把鍋甩給了手機應用廠商(手機反應太慢了啦,哈哈),其實現在微信也是這樣做的,不信你可以試試。
<style name="Appwelcome" parent="android:Theme.Translucent.NoTitleBar.Fullscreen"/>
透明化這種做法需要注意的一點,如果直接把Theme引入Activity,在啟動並執行時候可能會出現如下異常:
java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.
這個是因為使用了不相容的Theme,例如我這裡的Activity繼承了AppCompatActivity,解決方案很簡單:
1、讓其Activity整合Activity而不要整合相容性的AppCompatActivity
2、在onCreate()方法裡的super.onCreate(savedInstanceState)之前設定我們原來APP的Theme
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { setTheme(R.style.AppTheme); super.onCreate(savedInstanceState); }}
上面的2種做法,我們都需要將Theme引入對應的Activity
<activity android:name=".app.main.MainActivity" android:theme="@style/AppWelcome" android:screenOrientation="portrait"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity>
三、關於啟動最佳化
上面的做法其實可以達到"秒開"APP的效果,不過確不是真實的速度,在Activity建立過程中其實是會經過一系列framework層的操作,在日常開發中,我們都會去重寫Application類,然後在Application裡進行一些初始化操作,比如存放使用者標識的靜態化TOKEN,第三方SDK的初始化等。
這裡給出幾點建議:
1、不要讓Application參與業務的操作
2、不要在APPlication進行耗時操作,比如有些開發人員會在自己的APP裡一系列檔案夾或檔案(比如我自己),這些I/O操作應該放到"確實該使用的時候再去建立"亦或者是資料庫的一些操作。
3、不要以靜態變數的方式在Application中儲存資料等。
當然這是絕對的理想主義,把上面的"不要"2字之前添上"盡量"2字吧,畢竟在實際開發中,這樣做確實會讓我們方便許多。
對了,補充一點,布局也是很重要的,盡量的去減少布局的複雜性,布局深度,因為在View繪製的過程中,測量也是很耗費效能的。
好了,以上就是Android冷啟動實現APP秒開的全部內容,希望這篇文章的內容對大家日常開發App能有所協助,如果有疑問可以留言交流。