Android APP性能指标(二)

news2025/1/28 5:05:14

文章目录

  • 一、响应时间
      • 1.1 数据获取
      • 1.2 响应时间指标测试点
      • 1.3 启动速度测试点
      • 1.4 响应时间测试解决方法
  • 二、流量
      • 2.1 数据获取
      • 2.2 流量测试关注点
      • 2.3 测试标准
  • 三、电量
      • 3.1 连接手机
      • 3.2 数据获取
      • 3.3 获取APP的UID
      • 3.3 重置电池数据收集数据
      • 3.4 电量指标测试
  • 四、温度
  • 五、性能测试常见问题

在上一篇Android APP性能指标(一)中我们对CPU、内存、FPS和GPU四个常关注的指标进行学习。

本文将从响应时间、电量、流量等指标来了解Android性能。

一、响应时间

响应时间是衡量操作的APP达到期望效果的时间范围。如果一个软件,加载数据一直加载不出来,会对软件的日活、留存产生影响。

  • 应用冷启动<=600ms为优秀,<=800ms为良好,<=1000ms为可接受
  • 应用热启动<=200ms为优秀,<=400ms为良好,<=600ms为可接受

1.1 数据获取

获取package和activity的方法:adb logcat | grep -i displayed(需操作APP)
在这里插入图片描述

方法一:adb 方法

  1. 冷启动,需要提前确认程序是否在后台跑,如有则需要先kill应用程序
  2. 获取应用首次启动时间:adb shell am start -W -S -n package/activity
  3. 获取应用二次启动时间:adb shell am start –W –n
  4. 停止APP命令:adb shell am force-stop package

在这里插入图片描述
(1)WaitTime 就是总的耗时,包括前一个应用 Activity pause 的时间和新应用启动的时间;TotalTime+系统资源启动时间
(2)TotalTime 表示新应用启动的耗时,包括新进程的启动和 Activity 的启动,但不包括前一个应用 Activity pause 的耗时。也就是说,开发者一般只要关心 TotalTime 即可,这个时间才是自己应用真正启动的耗时

  使用am命令获取的时间只是apk从onCreate到onResume的时间,但不包含UI界面呈现出来的时间,所以考虑计算从am命令执行到logcat中有displayed出现的时候,视为app已经启动并展现,作为结束时间。此方法并不能完全计算出启动时间,有一定的误差。

方法二:使用charls 抓包,查看duration

在这里插入图片描述

1.2 响应时间指标测试点

  • 冷启动:应用首次启动所花费的时间
  • 热启动:应用非首次启动所花费的时间
  • 跳转:应用界面切换所花费的时间

1.3 启动速度测试点

  1. 冷启动速冻:首次启动app的时间间隔(只是启动时间,不包括页面加载)
  2. 热启动速度:非首次启动app的时间间隔(只是启动时间,不包括页面加载)
  3. 完全启动速度:从启动到首页完全加载出来的时间间隔
  4. 有网启动速度:从发起跳转,到页面完全加载出来的时间间隔
  5. 无网启动速度:从发起跳转,到页面完全加载出来的时间间隔

启动时间验收标准为 冷启动不超过1.5S,热启动不超过1S

1.4 响应时间测试解决方法

场景方法
获取单机事件触发到容器启动Native APP消耗的时间埋点
获取NativeAPP完全启动消耗时间查看system.log
获取Native调用PRC请求方法的延时时间埋点
获取RPC请求发出去过程中的具体数据埋点
获取RPC请求返回具体数据埋点
获取本地解析返回数据所消耗的时间埋点或者Traceview工具
获取界面渲染的时间慢速摄像机或埋点

二、流量

  如今,网络类型主要有2G、3G、4G、5G和WiFi,APP在使用不同网络时,我们要对其采取不同流量控制策略。如常用的视频APP,主要使用的网络类型为WiFi环境和蜂窝网络环境。

流量指标中涉及到的概念:

  • 中等负荷:应用正常操作
  • 高负荷:应用极限操作

2.1 数据获取

1、获取APP的PID:

  • 方法一:adb shell ps | grep 包名
    在这里插入图片描述
  • 方法二:adb shell dumpsys package 包名

2、获取流量数据命令:
adb shell cat /proc/获取的进程号PID/net/dev
在这里插入图片描述
注意:有些设备获取的流量数据有差异cat /proc/net/dev

3、tcpdump 抓包分析

  • 下载tcpdump工具,push到设备/data/local/tmp目录下

  • 在命令行中,输入tcpdump -v -i any -s 0 -c 2000 -w /文件地址
    在这里插入图片描述

  • tcpdump 工具命令参数说明
    -v/-vv/-vvv:,输出数据的详细程度,针对流量测试。
    -i:指定网卡(interface): any代表不限网卡
    -c: 指定接收包的数量,接收完成后自动停止抓包
    -s: 指每个包中最多截取的字节数,设置为0 时,为默认值262144

  • 使用Wirshark打开统计流量值,筛选ip.host=

2.2 流量测试关注点

  1. 应用首次启动流量值
  2. 应用后台持续运行时长2H的流量值
  3. 应用高负荷运行的流量峰值
  4. 应用中等负荷运行中的流量均值

2.3 测试标准

  • 不存在重复请求
  • 页面静默时或处于后台不应有流量增加
  • 缓存机制的逻辑合理
  • 在移动网络下不应自动下载素材等数据
  • 小缩略图小于5KB
  • 中缩略图小于25KB
  • 大缩略图小于50KB

三、电量

电量指标需要关注以下场景:

  1. 设备安装APK前后,待机功耗无明显差异
  2. 待机、操作页面、启动APK等常见操作,电量消耗均值正常
  3. 长时间使用APK,无异常耗电现象

  要通过adb命令来监控手机的耗电量,所以建议通过wifi的方式来连接手机,而不是用usb线来连接手机设备。usb方式连接手机会自动给手机充电,这样会影响对耗电量的统计的准确性。

3.1 连接手机

# 将 Android 设备与要运行 adb 的电脑连接到同一个局域网,比如连到同一个WiFi
# 先使用原装数据线把电脑与手机连接,手机在开发者选项中开启USB调试
# 使用adb devices命令查看是否与设备连接

$ adb devices
List of devices attached
86af3f27	device
# 显示device表示连接成功

# 断开数据线
$ adb connect 172.16.xxx.xxx:5555
unable to connect to 172.16.xxx.xxx:5555: Connection refused

# 输入 adb tcpip 5555命令
# 打印 “restarting in TCP mode port: 5555”表示启动成功

# 找到手机的 IP 地址
# 进入手机的WIFI连接,进入连接属性,查看手机的 IP
# 也可在「设置」-「关于手机」-「状态信息」-「IP地址」找到

# 输入adb connect '手机ip地址'
$ adb connect 172.16.xxx.xxx:5555
# 出现 connected to ip:5555 表示连接成功

3.2 数据获取

adb命令:adb shell dumpsys battery

Current Battery Service state:
  AC powered: false
  USB powered: true
  Wireless powered: false
  Max charging current: 500000    # 最大充电电流
  Max charging voltage: 5000000   # 最大充电电压
  Charge counter: 2449000
  status: 5               # 电池状态:2:充电状态 ,其他数字为非充电状态
  health: 2               # 电池健康状态:只有数字2表示good
  present: true           # 电池是否安装在机身
  level: 100              # 电量: 百分比
  scale: 100
  voltage: 4302           # 电池电压
  temperature: 385        # 电池温度,单位是0.1摄氏度
  technology: Li-poly     # 电池种类

3.3 获取APP的UID

adb shell COLUMNS=512 top
在这里插入图片描述
或者adb shell ps | grep 包名,Windows电脑将grep替换成findstr即可
在这里插入图片描述

3.3 重置电池数据收集数据

  • 清除已有的耗电量数据
    adb shell dumpsys batterystats --enable full-wake-history

  • 重置设备耗电量数据
    adb shell dumpsys batterystats --reset

  • 然后执行业务场景,测试完成之后再执行以下命令取出APP电量消耗日志(把数据重定向到本地)
    adb shell dumpsys batterystats > 文件地址

在文件中搜索 Estimated power use (mAh)即可跳转到App电量消耗位置:
在这里插入图片描述
之前获取的Uid值 u0_a1619 需要将下划线 _ 去掉变成 u0a1619 ,然后通过该Uid在日志文件中查找则可搜索到该APP对应的耗电量。

其中, Uid u0a1619:0.0978 中的 0.0978 为该APP在测试期间消耗的总电量,单位为 mAh ,圆括号中详细说明了电量消耗的详细信息。

3.4 电量指标测试

电量指标需要从软件和硬件两方面都要进行测试。

硬件端:需要硬件测试工程师使用万用表、功耗仪进行测试。满足市场行业标准

软件端:

  • 方式一:可以使用第三方工具进行测评
  • 方式二:命令端获取电量数据

四、温度

Android 设备运行过程中,设备温度异常不仅对用户体验带来不好影响,同时也存在安全方面隐患。

温度指标需要关注如下几个场景:

  1. 设备满负荷情况,设备温度峰值无异常
  2. 设备APK长时间播放,设备温度均值无异常
  3. 设备常规操作如点击、启动APK等温度正常

温度指标数据与电量指标获取方式都一样的

  • adb shell dumpsys battery
    在这里插入图片描述
  • temperature:温度(int类型),单位:0.1度

五、性能测试常见问题

在性能测试过程中,经常会遇到如下问题及原因:

问题原因
APP连接超时网络中断;APP 请求接口异常
APP 闪退Android缓存垃圾过多;运行程序多,导致内存不足等;版本兼容问题
卡顿、黑白屏系统CPU、GPU资源不够;过度绘制
崩溃APP常常表现为Crash
交互性能差其他APK、弹框干扰
内存泄漏APK新建的对象没有释放,导致内存一直被占用
内存溢出APK申请内存不够时

参考文档:https://juejin.cn/post/7068239461607276581#heading-5

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1496815.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

stm32学习笔记:I2C通信外设原理+实验

软件实现和硬件实现 串口通信为异步时序&#xff0c;用软件实现很麻烦&#xff0c;基本上用硬件实现 而I2C协议通信为同步时序&#xff0c;软件实现简单且灵活&#xff0c;硬件实现比较麻烦&#xff0c;故软件比较常用 但I2C硬件实现功能比较大&#xff0c;执行效率高&#xff…

四信全球化拓展再启新篇!LoRa传感器与云平台领航智能感知时代

随着科技浪潮的不断推进&#xff0c;物联网已逐渐融入我们的生活。刚刚结束的MWC24盛会上&#xff0c;四信带来了一系列前沿技术成果&#xff0c;不仅将5G技术成功扩展至当前市场主流类型的终端&#xff0c;更携手联通、ASR等业界巨头&#xff0c;在连接、5G RedCap、AI、LoRa以…

章鱼网络进展月报 | 2024.2.1-2.29

章鱼网络大事摘要 1、Omnity 完成了核心组件的原型开发&#xff0c;正在测试&#xff0c;未来将首先支持 Runes 资产跨链。 2、$NEAR Restaking 质押总量超过400万美元。 3、章鱼网络受邀参加 ETHDenver 2024&#xff0c;并且与 ICP 共同组织活动&#xff0c;介绍 Omnity 的…

记一次线上问题-Druid数据源配置失败

一、背景是这样的 我们的服务是spring 服务。 数据库是mysql。 接到公司要求&#xff0c; mysql数据源配置&#xff08;JDBCURL地址&#xff09; jdbc:mysql://IP:PORT/dbname?Unicodetrue&characterEncodingutf8&useSSLfalse 需要添加参数 allowMultiQueriestr…

SkyWalking 本地启动以及闪退问题

1. 下载包 Downloads | Apache SkyWalking SkyWalking APM包含OAP和UI Java Agent 就是Java 的探针 2. 运行 UI 默认端口是 8080&#xff0c; OAP 默认端口是 11800&#xff08;grpc&#xff09;12800&#xff08;http&#xff09; 如果占用可以修改配置文件 UI 项目的配…

Vue中如何处理用户权限?

在前端开发中&#xff0c;处理用户权限是非常重要的一个方面。Vue作为一种流行的前端框架&#xff0c;提供了很多便捷的方式来管理用户权限。本文将介绍一些Vue中处理用户权限的方法 1. 使用路由守卫 Vue Router提供了一个功能强大的功能&#xff0c;即导航守卫&#xff08;N…

如何使用宝塔面板搭建Discuz并结合cpolar实现远程访问本地论坛

文章目录 前言1.安装基础环境2.一键部署Discuz3.安装cpolar工具4.配置域名访问Discuz5.固定域名公网地址6.配置Discuz论坛 前言 Crossday Discuz! Board&#xff08;以下简称 Discuz!&#xff09;是一套通用的社区论坛软件系统&#xff0c;用户可以在不需要任何编程的基础上&a…

OpenAI-Sora学习手册

通过Sora看2024红利&#xff1a;文生视频&#xff0c;虽然AI不一定是风口&#xff0c;但一定是未来深入到生活工作&#xff0c;乃至思考的必备工具。 目录 Sora介绍 Sora基础介绍 Sora官方网址 Sora的价值 1.物理世界的交互 2.创意世界的绽放 3.多角色、更精准、更细节…

全志D1s开发板裸机开发之坏境搭建

环境搭建 开发板介绍 张天飞老师编写的《RISC-V体系结构编程与实践》&#xff0c;里面的源码是基于 QEMU 模拟器的&#xff0c;可以认为它是一款虚拟的开发板。如果需要在真实开发板上学习&#xff0c;可以使用百问网的 DongshanPI-D1S 开发板。 DongshanPI-D1S 是百问网推出…

大语言模型的知识融合(ICLR2024)

一、写作动机&#xff1a; 虽然从头开始训练大型语言模型&#xff08;LLMs&#xff09;可以生成具有独特功能和优势的模型&#xff0c;但这种方法成本高昂&#xff0c;而且可能导致功能冗余。 二、主要贡献&#xff1a; 入了 LLMs 知识融合的概念&#xff0c;旨在结合现有 LL…

Python基于opencv的人脸识别上课签到考勤系统,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

一图看懂:什么是“新质生产力”?

◆2023年9月&#xff0c;首次提出“新质生产力”。 ◆2024年1月&#xff0c;强调“加快发展新质生产力&#xff0c;扎实推进高质量发展”。 ◆2024年3月&#xff0c;《政府工作报告》中提出&#xff0c;要大力推进现代化产业体系建设&#xff0c;加快发展新质生产力。充分发挥…

黄坤朋:沉浸声系统技术方案和调试| 演讲嘉宾公布

一、3D 音频分论坛 3D 音频分论坛将于3月27日同期举办&#xff01; 3D音频技术不仅能够提供更加真实、沉浸的虚拟世界体验&#xff0c;跨越时空的限制&#xff0c;探索未知的世界。同时&#xff0c;提供更加丰富、立体的情感表达和交流方式&#xff0c;让人类能够更加深入地理解…

Xilinx 7系列 FPGA硬件知识系列(一)——FPGA选型参考

目录 1.1 Xilinx-7系列产品的工艺级别 ​编辑1.2 Xilinx-7系列产品的特点 1.2.1 Spartan-7系列 1.2.2 Artix-7系列 1.2.3 Kintex-7系列 1.2.4 Virtex-7系列 1.3 Xilinx-7系列FPGA对比 1.3.1 DSP资源柱状图 ​1.3.2 Block RAM资源柱状图 ​1.3.3 高速串行收…

【Java设计模式】八、装饰者模式

文章目录 0、背景1、装饰者模式2、案例3、使用场景4、源码中的实际应用 0、背景 有个快餐店&#xff0c;里面的快餐有炒饭FriedRice 和 炒面FriedNoodles&#xff0c;且加配菜后总价不一样&#xff0c;计算麻烦。如果单独使用继承&#xff0c;那就是&#xff1a; 类爆炸不说&a…

浅谈漏洞扫描技术

1. 什么是漏扫 漏洞扫描技术是指利用已有的漏洞数据库&#xff0c;使用扫描匹配的方式对计算机系统进行脆弱性检测&#xff0c;从而实现漏洞发现的一种安全防护手段&#xff0c;漏洞扫描的结果可以用于指导网安的管理人员及时处理系统中的漏洞&#xff0c;防患于攻击之前。 漏…

使用YOLOv7进行视频实时姿态估计

本文基于YOLOv7进行人体姿态的实时估计,并附录完整代码。 概述 YOLO(You Only Look Once)是一种用于目标检测的方法论,同时也是构建于该方法论之上的一系列模型。 自2015年YOLOv1诞生以来,其作者相继提出了YOLOv2(YOLO9000)和YOLOv3等后续版本,并在随后的几年里,深度…

【微信小程序】屏幕适配

在网页中一般是使用 rem 单位&#xff0c;它能够根据html的字号大小自动改变尺寸&#xff0c;开发者可以动态的计算屏幕尺寸&#xff0c;然后根据屏幕大小的不同设置html的字号 小程序解决适配使用 rpx 单位&#xff0c;它能够根据屏幕大小自动进行转换。 每一个机型的宽度和高…

如何制作一份精美的数据分析可视化报告?详细教程

在数据可视化分析的最后阶段&#xff0c;所有的分析、研究、推导以及得出的结论&#xff0c;都汇总成了一份详实的报告。这份报告不仅是对整个数据分析旅程的总结&#xff0c;更是向读者展示这段旅程所取得的成果。 那么&#xff0c;数据分析报告该如何制作呢&#xff1f;不用…

2024年软件设计师全套资料

2024年5月软件设计师全套视频、历年真题及解析、历年真题视频解析、教材、模拟题、重点笔记等资料 1、2023年11月、2022年、2021年全套教程精讲视频。 2、软件设计师2009-2023年5月历年真题及解析&#xff08;综合知识、案例分析&#xff09;、2009-2023历年真题视频解析。 3…