android官方文档 app startup time 对App启动的描述,应用启动分为冷启动、热启动、温启动,本文主要解决耗时最长的冷启动。
第一步:冷启动耗时统计
adb shell am start -S -W [packageName] / [activityName]
- -s 表示杀死程序重启
- -w 启动并输出相应的数据
- packageName applicationId
- activityName 启动页的名称,Luauncher Activity
执行上述命令,可以打印出应用启动时间,但是这个时间不准确,也没法在线上实时监测。
所以介绍一个线上可用的方案就是手动打点,在自己的 Application中的attachBaseContext方法中记录开始时间戳,并在启动页LaunchActivity中的根布局view的addOnDrawlistenter回调完成记录结束时间戳。即可统计应用的打开到view展示的真实事件。当然还有android自带的工具traceView 与 systrace也可以统计启动时间,但是加入启动代码影响性能可能对启动时间造成误导。
第二步:优化耗时
启动时间收集之后,就需要收集各个初始化和三方库的具体耗时。这也可以采用打点的方式,但是比较繁琐。但是可以采用AOP的方式,这种方式跟友好,而且它还有更强大的用去,以后会给大家讲到。
当收集到具体耗时