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. 再通过逐帧分析图片,找到点击的时间以及打开指定界面的时间,从而推算启动时间

03-20 专项测试-APP 启动性能分析相关推荐

  1. 移动端测试 APP启动性能分析 WebView性能分析 H5性能分析 卡顿分析 帧分析 CPU统计 网络流量分析 耗电量指标 弱网测试 健壮性测试 兼容性测试 Amdahl

    Android官网使用指南性能:https://developer.android.com/topic/performance 一.APP启动性能分析 APP的启动过程 调用起APP.创建一个空白窗口 ...

  2. iOS App 启动性能优化

    为什么80%的码农都做不了架构师?>>>    本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq. ...

  3. SpringBoot系列三:SpringBoot基本概念(统一父 pom 管理、SpringBoot 代码测试、启动注解分析、配置访问路径、使用内置对象、项目打包发布)...

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.了解SpringBoot的基本概念 2.具体内容 在之前所建立的 SpringBoot 项目只是根据官方文档实现的一个基础程 ...

  4. 分析启动耗时 android,Android app启动耗时分析

    首先编译你的程序,打开Android Studio里面的Android Monitor,找到下图的按钮 <img src="//bbsm ...

  5. Android 系统性能优化(21)---App启动原理分析及启动时间优化

    一.启动原理解析 Android是基于Linux内核的,当手机启动,加载完Linux内核后,会由Linux系统的init祖先进程fork出Zygote进程,所有的Android应用程序进程以及系统服务 ...

  6. 【虫师--系列20】性能测试知多少---性能分析与调优的原理

    转自: http://www.cnblogs.com/fnng/archive/2013/03/19/2970315.html   作者:虫师 最近一直纠结性能分析与调优如何下手,先从硬件开始,还是先 ...

  7. APP启动方式分析——冷启动、热启动、温启动

    APP启动分析 Cold start At the beginning of a cold start, the system has three tasks. These tasks are: 1. ...

  8. android专项测试 方案,Android性能专项测试.pdf

    目录 前言 battery-historian试用 MemoryMonitor工具 HeapViewer工具 AllocationTracker(DeviceMonitor) AllocationTr ...

  9. AB压力测试开源WAF性能分析

    AB压力测试简介 ab -n 10000 -c 100 http://172.28.13.40/myzoo/index.php ab -n 10000 -c 100 http://172.27.20. ...

最新文章

  1. day16 递归函数
  2. 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和
  3. MySQL数据库自动添加时间戳
  4. [JSON].typeOf( keyPath )
  5. 策略模式、观察者模式、代理模式、装饰模式 应用场景和实现
  6. android屏幕适配流程,Android屏幕适配姿势
  7. 【Java】HashMap 和 Hashtable 的 6 个区别
  8. 双击java安装包没有反应_雨林木风Win7下双击JER安装包没有反应的解决技巧
  9. Java动态代理(dynamic proxy)
  10. Office Word 目录制作页码右对齐方法
  11. The little Schemer
  12. 阐明iOS证书和provision文件
  13. Swoole vs Workman
  14. 不同麻醉方案以及清醒条件下大鼠大脑连接模式分析
  15. Wolfram Mathematica学习笔记1
  16. Python 爬虫十六式 - 第七式:RE:用匹配来演绎编程的艺术
  17. Opencv中BGR、YUV、YUV_I420\NV12分析
  18. 新增收货地址【项目 商城】
  19. 社交电商+新零售=社交新零售,没思路的创业者看过来
  20. 我叫mt4最新服务器,我叫mt4怎么看服务器等级上限 经验上限查看方法详解

热门文章

  1. 如何选用NAS、OSS和EBS
  2. Kubernetes 学习总结(20)—— Kubernetes 与微服务和容器之间是什么关系?
  3. Java基础学习总结(164)——别让Lombok使你的Java代码处于“亚健康”状态
  4. Redis学习总结(14)——图解redis五种数据结构底层实现(动图版)
  5. element table多选表格_【经验总结】vue + element-ui 踩坑—— table 篇
  6. FreeTreeView一个可添加、删除、修改的无限极树形结构
  7. Android中你可能忽略的知识点(1)-分辨率那些事
  8. oracle 用户解锁和修改用户密码
  9. 2007浙大复试上机考试题目1--最小长方形
  10. 20171221L09-10老男孩Linux运维实战培训-Nginx服务生产实战应用指南02