本系列博文 基于是前微信高级工程师张绍文专栏 《Android开发高手课》的读书笔记。
文章所写内容是本人读完的感悟,需要原文的朋友请自行购买。
启动优化篇
在说如何对启动时间进行优化之前,我们得先知道从用户点击应用图标开始,一共经历了那些阶段。
主要阶段如下图.
T0~T1阶段
这个阶段是手机系统解析点击事件,效应快慢跟手机性能有关
T1~T2阶段
系统在正式启动应用之前,会根据应用设置的Theme设置一个预览界面.
应用启动白屏也是发生在这里,如果你没有设置对应的Theme,并且Activity的onCreate函数执行所需要的时间过长,就会出现白屏的情况.比较可行的解决方式是给启动页的Theme设置一张背景图。如下
<activity
android:name=".view.SplashActivity"
android:theme="@style/LauncherTheme">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<style name="LauncherTheme" parent="AppTheme">
<item name="android:windowBackground">@drawable/logo_bg</item>
</style>
这样的话,在点击应用图标后,就会先显示一张背景图,
另外还可以将预览窗口指定为透明的,这样用户在看到闪屏页之前会一直带着桌面,但这样就会给用户一种点了很久才会看到界面的感觉。
在预览界面显示之后,便会创建Application和闪屏页,大部分应用都会在这个时候初始化各种功能.因而导致
预览界面~闪屏界面显示 这个时间会很长.
如何优化
除了必须要在Application中初始化的功能,我们可以把其他一些功能的初始化移到闪屏页中,因为大多数应用的闪屏页都会停留几秒钟。这里还要注意的是,移到闪屏页初始化的功能代码,不要放在onCreate生命周期下,而是另外开启一个线程来做初始化行为。
另外,多线程的切换会影响CPU的性能.所以如果你的应用在启动时需要开多个线程的话,需要考虑用线程池来维护
T2~T3阶段
在闪屏页显示的时候,会开始主页视图的绘制,这个时候需要注意,因为之前说到,闪屏页中会开启子线程去初始化一些功能。如果需要初始化的模块过多,开始加载首页的时候还没初始化完成,恰巧这个时候首页又需要用到这个模块.那这个时候就会报错。
所以首页需要用到的模块必须得在调用之前初始化成功。
T3~T4阶段
首页正常显示了,但这个时候你不一定就能点击,问题还是在于有些功能模块的代码还未初始化完成。
总结
界面显示上:
预览窗口可以采用自由logo背景或者与闪屏页共用,以防止白屏.
模块初始化:
application中初始化一部分必要的模块,闪屏页通过子线程加载一部分模块,剩下的非紧急的模块用懒加载的方式,
其中懒加载要防止集中化,不然可能会出现一次加载太多,导致某个界面无法操作的情况。
张老师课中还涉及许多监控和底层相关的东西,我个人接触的较少,这里就不在赘述了。