Android 启动速度优化

启动优化

随着项目越来越大,App的启动时间愈来愈长,有必要对给初始化进行梳理,并预留初始化接口。
经过一番折腾后,并对比优化前,成果还不错:优化35%-50%。

Google文档:https://developer.android.com/topic/performance/launch-time.html

1.启动时间统计

  • a.第一种方式查看Logcat日志,搜索关键字:Displayed。(注:范围一定选择 No Filters )


    image
    image
  • b.第二种方式adb命令启动:adb shell am start -W -n 应用包名/Launch Activity全路径


    image
    image
  • c.第三种,在所有代码执行完后加上 reportFullyDrawn() ,查看Logcat日志Fully drawn时间
system_process I/ActivityManager: Fully drawn {package}/.MainActivity: +1s54ms

2.启动耗时代码

image
image

由图可见影响App启动时间操作主要在:

  • Application onCreate()
  • Activity onCreate()

主要操作位置部分已经了解了,接下来就是对耗时操作进行定位了

3.耗时操作定位

  • a.第一种生成trace文件。由于启动过快,无法利用Android Studio进行打点。这时候可以利用代码对想定位的代码块进行分析。

    • Debug.startMethodTracing("/sdcard/admtrace1.trace"); 开始
    • Debug.stopMethodTracing(); 结束
    • 运行结束后将trace文件拖进Android
    • Studio进行分析即可(示例为release包,为方便分析建议打debug包进行分析)


      image
      image
  • b.LogCat (建议Release包)

    • 逐句代码进行log,定位每一句代码执行耗时时间
    • 如果Release包,需要打开Log操作。
          buildTypes {
              release {
                 debuggable true
              }
          }
      
    • 推荐使用Log.简单直观。

4.优化方案

定位到耗时操作后,这时候往往只需要对定位到的主要耗时操作进行优化便可。这样不用动大部分的代码,缩小影响范围。

  • 1.体验优化。

    • 很多App没有做体验优化,导致点击App后,icon会灰置2s不等...这个等待的体验会非常不好,对此可以设置 Launch Activity 默认的Theme来进行规避,Theme 可以是一张默认的图片(建议使用.9图片),可以是默认的颜色来填充。接下来体验下顺滑的秒启感觉。
    <style name="StartTheme" parent="AppStartTheme">
            <item name="android:windowNoTitle">true</item>
            <item name="android:windowActionBar">false</item>
            <item name="android:windowFullscreen">true</item>
            <item name="android:windowBackground">@drawable/splash</item>
        </style>
    
    <?xml version="1.0" encoding="utf-8"?>
    <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <!-- 背景颜色 -->
        <item android:drawable="@color/color_1" />
    
        <item>
            <!-- 图片 -->
            <bitmap
                android:gravity="fill"
                android:src="@drawable/bg" />
        </item>
    </layer-list>
    
  • 2.异步初始化

    • 对定位到的耗时操作进行分析,尽量放倒异步线程中进行初始化操作,不占用主线程资源。
  • 3.延时初始化

    • 对不能放在异步初始化的代码,进行延后加载。炒鸡好使。
  • 4.动态申请权限不建议放在Application中,放在LaunchActivity中。

  • 5.LaunchActivity中尽量在View绘制完成后,在进行相关初始化操作。UI绘制完成回调后进行初始化比较好。

getWindow().getDecorView().post(new Runnable() {

  @Override public void run() {
    ……
  }
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,455评论 25 708
  • 请保持淡定,分析代码,记住:性能很重要。 启动时间优化 毫无疑问,应用的启动速度越快越好。 本文可以帮助你优化应用...
    Mupceet阅读 11,466评论 5 19
  • 每个人的一生都想全感了,有对象了就有安全感了,有房子了就有安全感了,有家了就有安全感了,有孩子了就有安全感了;然而...
    络婷阅读 534评论 0 0
  • 上篇交互设计流程的“闭环”问题(上)讲到了的是打通断头路的问题,这篇继续讲讲剩下的两种方法。 2、设置延长线 如果...
    妖叶秋阅读 2,616评论 8 50
  • 我们是可以时时刻刻都保持与宇宙紧密的链接,这个就来会自于我们对光保持一份警觉。 今天我们就尝试着做任何事情都去问一...
    啊杜_阅读 178评论 0 0