Android启动速度优化
2017-08-21 20:17
211 查看
启动优化
随着项目越来越大,App的启动时间愈来愈长,有必要对给初始化进行梳理,并预留初始化接口。经过一番折腾后,并对比优化前,成果还不错:高端机器优化35%,低端机器优化50%。
Google文档:https://developer.android.com/topic/performance/launch-time.html
1.启动时间统计
a.第一种方式查看Logcat日志,搜索关键字:Displayed。(注:范围一定选择 No Filters )b.第二种方式adb命令启动:adb shell am start -W -n 应用包名/Launch Activity全路径
c.第三种,在所有代码执行完后加上 reportFullyDrawn() ,查看Logcat日志Fully drawn时间
system_process I/ActivityManager: Fully drawn {package}/.MainActivity: +1s54ms
2.启动耗时代码
由图可见影响App启动时间操作主要在:
* Application onCreate()
* Activity onCreate()
主要操作位置部分已经了解了,接下来就是对耗时操作进行定位了
3.耗时操作定位
a.第一种生成trace文件。由于启动过快,无法利用Android Studio进行打点。这时候可以利用代码对想定位的代码块进行分析。Debug.startMethodTracing(“/sdcard/admtrace1.trace”); 开始
Debug.stopMethodTracing(); 结束
运行结束后将trace文件拖进Android
Studio进行分析即可(示例为release包,为方便分析建议打debug包进行分析)
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 App优化之提升你的App启动速度
- Android App优化之提升你的App启动速度之理论基础
- 浅谈Android开机启动速度优化
- 优化Android 应用启动速度(应用启动慢的真正原因探究)
- Android 应用启动速度优化
- Android性能优化第(八)篇---App启动速度优化之耗时检测处理
- Android内核开发:系统启动速度优化
- Android App优化之提升你的App启动速度之实例挑战
- Android App优化之提升App启动速度实例
- Android优化应用启动速度
- 浅谈Android开机启动速度优化(含应用程序启动速度优化)
- Android内核开发:系统启动速度优化-Android OS启动优化(转)
- 浅谈Android开机启动速度优化(含应用程序启动速度优化)
- Android性能优化之加快应用启动速度
- Android内核开发:系统启动速度优化
- 浅谈Android开机启动速度优化(含应用程序启动速度优化)
- 浅谈Android开机启动速度优化(含应用程序启动速度优化)
- Android优化应用启动速度
- 浅谈Android开机启动速度优化(含应用程序启动速度优化)
- Android App优化之提升你的App启动速度之实例挑战