Activity 启动流程
Application OnCreate
- 加载第三方的 sdk
Activity OnCreate
- 加载自身的逻辑
- 发送远程数据请求
- 渲染界面
APP 启动性能指标
- 冷启动:最重要的启动指标,着重优化,建议时间 5 秒
- 暖启动:建议时间 2 秒
- 热启动:建议时间 1.5 秒
- 首屏启动
测试的主要流程
- adb logcat:不够准确
- 录屏 + 视频拆帧:较准确,需要人工操作
- uiautomator 等自动化工具,进行 200ms 巡检界面变化
- traceview
- 硬埋点:最准确,而且覆盖度更广
adb logcat
- 清理缓存数据:
adb shell pm clear package
- 停止进程:
adb shell am force-stop package
- 启动 APP:
adb shell am start -S -W package/activity
- 获取数据:
adb logcat | grep -i displayed
通过 adb logcat 获取结果:
- startTime:记录刚准备调用 startActivityAndWait() 的时间点
- endTime:记录 startActivityAndWait() 函数调用返回的时间点
- waitTime:startActivityAndWait() 调用耗时;waitTime = endTime - startTime
使用 ffmpeg 拆帧
- 清除应用缓存:
adb shell am force-stop package
- 进行 30s 录屏,并存放到手机的指定地址:
adb shell screenrecord --bugreport --time-limit 30 录屏文件路径 &
- 启动APP,跳转到指定界面:
adb shell am start -S -W package/activity
- 把录屏文件从手机拉取到电脑:
adb pull 录屏文件路径 存放路径
- 将视频转换为 gif 格:
ffmpeg -i 录屏文件 拆分格式
- 将视频拆帧,每秒拆成10份,存储为jpg格式图片:
ffmpeg -i 录屏文件 -r 10 frames_%03d.jpg
- 再通过逐帧分析图片,找到点击的时间以及打开指定界面的时间,从而推算启动时间
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。