启动优化

APP启动的时候会有一个短暂的白屏现象
产生的原因是在application的默认主题style/AppTheme的父主题中设置windowBackground为白色

<style name="Platform.AppCompat.Light" parent="android:Theme.Holo.Light">
<item name="android:windowBackground">@color/background_material_light</item>
</style>

方法一:给白屏加一个图片
在AndroidManifest.xml中application的style添加一个背景图替代这个白屏或者在MainActivity的style中添加这个背景图

<item name="android:windowBackground">@drawable/guide_window_background</item>

方法二:
在MainActivity的style里面设置窗口是透明

<item name="android:windowIsTranslucent">true</item>

或者设置禁用窗口的预览动画

<item name="android:windowDisablePreview">true</item>

这两个都会有点击APP图标短暂延迟打开APP的现象。

查看activity的启动时长

adb shell am start -W [PackageName]/[PackageName.MainActivity] //W大写
时长
  1. ThisTime:代表当前activity(就是这个Splash)启动时长,一般和TotalTime时间一样,除非中间有多个activity的启动,这样TotalTime就会比ThisTime长。
  2. TotalTime:应用的启动时间,包括创建进程+Application初始化+Activity初始化到界面显示。
  3. WaitTime:一般比TotalTime大点,包括系统影响的耗时。

这个命令也许你会出现这个情况

需要在AndroidManifest中给activity添加一个属性

android:exported="true"

Trace 分析耗时

如果要分析一个方法的的耗时情况,先要生成对应的trace文件,如分析下面的initNim()方法。

        File file = new File(Environment.getExternalStorageDirectory(),"app");
        Debug.startMethodTracing(file.getAbsolutePath());
        initNim();
        Debug.stopMethodTracing();

运行完项目SD卡中就会有个app.trace的文件,把文件拖入android studio中显示。


trace
  • 黄色线方法执行的时长
  • Top Down 至上而下的查看
  • Buttom Up 至下而上的查看


  • total总耗时
  • Children 子方法耗时
  • Incl Real Time
    某函数运行的真实时间(以毫秒为单位),内含调用其它函数所占用的真实时间
  • Excl Real Time
    某函数运行的真实时间(以毫秒为单位),不含调用其它函数所占用的真实时间
  • Call+Recur Calls/Total
    没展开某个方法时:会显示该方法被程序员主动调用次数,以及被自身递归调用次数;例如:2+3,程序员调用两次,自己递归调用3次。
    展开某个方法时:父方法会显示:其调用(程序员主动调用,非递归)该方法的次数/该方法的总次数,例如:2/5,说明该方法总共被调用5次其中父方法主动调了他2次子方法会显示:子方法被其调用(程序员主动调用)的次数/子方法被调用的总次数,例如1/5

不要再Application类的onCreate中初始化一些第三方,如网络框架,图片加载框架等等,更不能做一些文件的操作,否则APP启动会很慢。
如果一定要在这里做一些初始化的操作,可以使用子线程。
最好是写个util,用懒汉式单例,第一次使用的时候会慢点。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容