03-20 专项测试-APP 启动性能分析

Activity 启动流程

  • Application OnCreate

    • 加载第三方的 sdk
  • Activity OnCreate

    • 加载自身的逻辑
    • 发送远程数据请求
    • 渲染界面

APP 启动性能指标

  1. 冷启动:最重要的启动指标,着重优化,建议时间 5 秒
  2. 暖启动:建议时间 2 秒
  3. 热启动:建议时间 1.5 秒
  4. 首屏启动

测试的主要流程

  1. adb logcat:不够准确
  2. 录屏 + 视频拆帧:较准确,需要人工操作
  3. uiautomator 等自动化工具,进行 200ms 巡检界面变化
  4. traceview
  5. 硬埋点:最准确,而且覆盖度更广
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 拆帧
  1. 清除应用缓存: adb shell am force-stop package
  2. 进行 30s 录屏,并存放到手机的指定地址: adb shell screenrecord --bugreport --time-limit 30 录屏文件路径 &
  3. 启动APP,跳转到指定界面:adb shell am start -S -W package/activity
  4. 把录屏文件从手机拉取到电脑:adb pull 录屏文件路径 存放路径
  5. 将视频转换为 gif 格:ffmpeg -i 录屏文件 拆分格式
  6. 将视频拆帧,每秒拆成10份,存储为jpg格式图片:ffmpeg -i 录屏文件 -r 10 frames_%03d.jpg
  7. 再通过逐帧分析图片,找到点击的时间以及打开指定界面的时间,从而推算启动时间
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

肖遥Janic

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值