一、启动耗时统计
am start -S -W com.example.health/.LoginActivity
-S 参数为先停止,然后再次进行启动,-S顾名思义为Stop的意思
二、APP首次打开白屏解决方案
在manifest文件中,给启动Activity加入自定义的Theme,代码如下:
<style name="MyAppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="android:windowBackground">@mipmap/top1</item>
<item name="android:windowFullscreen">true</item>
</style>
然后在onCreate中设置新的主题
protected void onCreate(Bundle savedInstanceState) {
setTheme(R.style.AppTheme);
super.onCreate(savedInstanceState);
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
三、通过代码的方式抓取trace文件
必须注意需要开启sdcard的读写权限,会在sdcard的根目录生成lgj.trace文件
public MyApplication(){
// 开启trace追踪
Debug.startMethodTracing("lgj");
}
// 关闭trace追踪
Debug.stopMethodTracing();
使用CPU profile 观察启动过程中,每个方法的耗时情况
4、启动耗时总体的优化策略
1、合理的使用异步初始化,延迟初始化,懒加载机制
2、启动过程避免耗时操作,如数据库、I/O操作不要放在主线程
3、类加载优化:提前异步执行类加载
4、合理使用IdelHandler 进行延时加载
5、简化布局