手机发烫是为何—— App 电量测试定位方法

本文分享了移动应用电量测试的重要性和方法,包括理解Android系统电量统计原理、开发自定义测试工具以准确定位问题、以及实现自动化测试流程来提高效率。

为什么要做电量测试

随着移动互联网的快速发展,手机的实用性、娱乐性越来越强。日常使用中发现,安装了应用后,即使不怎么使用,电量也会消耗很快。但如果恢复出场设置充满电后,手机可以待机很长时间。真相只有一个:手机耗电的最终元凶是软件。

在各大应用市场中搜索“电量管理”相关应用,每个应用都有几万到几十万次的下载量。这说明,越来越多的用户开始关注应用电量问题。所以,在研发阶段,有效的检测和定位电量问题,是十分重要的工作。

如何能够有效的检测和定位应用的电量问题呢?可以从两个方面入手:一方面,从手机系统入手,了解ROM对应用电量消耗的统计原理,进而从代码层规避不必要的电量消耗。另一方面,从应用本身入手,在保证用户体验的前提下,尽可能减少不必要的操作。

下面分享下,在对应用电量优化过程中所做的专项测试工作。

业界通用的电量测试方法

![](http://i.imgur.com/umpEA4c.jpg)

小结:可以看出,目前业界现有的电量测试方法很多。除了借助于其他设备监测整机电量消耗的硬件测试方案外,android系统也提供了各种获取应用电量消耗的方法。

方法各有优势。但,都是定位于获取整体电量消耗(整机、应用)。对于开发和测试人员最关注的问题:有效定位导致应用电量消耗的具体原因,仍然无法解决。

我们需要的电量测试

在产品研发阶段,能够快速获取应用电量消耗,准确定位问题原因的测试方法,是开发和测试人员最需要的方法。所以,从2016年初开始,我们确定了电量测试工作的开展方向:

1、理清原理:Android系统电量统计原理;

2、调整策略:关注整机的硬件测试方案替换为关注APP的软件测试方案;

3、准确定位:获取更详细的数据;

4、提升效率:自动化电量测试方案建设。

Step1理清原理

在对业界现有测试工具的了解中,我们发现Android提供了对应用电量统计的系统工具“耗电排行”。
通过解包ROM源码并反编译Settings.apk,找到了Android系统对应用电量消耗统计的接口:com.android.internal.os.BatteryStatsHelper(5.0之后类名)中的方法processAppUsage。该方法中统计了系统对应用各部分的电量消耗:

在解读源码的过程中,发现了一个有意思的文件power_profiler.xml。该文件中列出了手机厂商针对机型硬件定义的单位时间元器件电量消耗值。由于文件内容的差异,从而导致了,同样的应用、同样的操作场景、同样的外界环境,在不同手机上电量消耗不同。

![](//blog-10039692.file.myqcloud.com/1493347884314_7551_1493347937351.jpg)

不同手机power_profiler.xml文件

小结:通过解读源码,掌握到系统对应用电量消耗的统计方法。如果可以在测试过程中获取到组成应用整体消耗的各部分的消耗值,就可以大体定位到问题方向。

Step2调整策略

硬件测试采集的是整机的电流值,由于外接干扰因素的影响其他应用、手机环境、网络环境、人为因素等,经常导致的测试结果是:数据波动大、无法定位原因。并且,随着手机硬件、外观的调整,越来越多的机器无法自主拆卸电池,而厂商对内置版本的电量要求却越来越严格。目前现有的硬件测试方案,无法继续满足在研发阶段对应用电量的有效保障。

既然Android系统已经提供了对单个应用的电量统计应用,我们就可以利用源码并结合实际的需求,对已有的系统工具进行二次开发,通过软件的方式完成对单个应用耗电量的测试。

Step3准确定位

理清了系统对应用的电量统计原理后,我们发现“耗电排行工具”并没有详细输出组成应用总体电量消耗的每一部分的消耗值。所以,在解决“准确定位”的问题上,首先能够做的工作就是进一步细化数据。

“工欲善其事必先利其器”。

我们开发了以下两个工具,支持获取更详细的数据。

【工具一:PowerStat2.0】

该工具是对系统“耗电排行工具”的二次开发。使用系统计算公式和API进行计算。
相比较原工具,完善以下几个特性:

1、数据展示:除了展示组成应用总体电量消耗的每一部分的消耗值,同时显示使用时长、次数及数据传输量信息;

2、传感器细分;

3、展示power_profiler.xml

4、提供定时测试功能。

【工具二:CPUMonitor】

通过日常监控和用户反馈发现,导致应用电量消耗升高的最常见问题是CPU问题:

华为手机用户反馈电量问题

日常监控电量异常升高问题

依据操作系统的概念—进程是由一个或多个线程组成,可以将“准确定位”问题进一步细化到获取线程的CPU时间片消耗。

为了能够在电量测试的同时进行CPU时间片数据的采集,并尽可能减少其他消耗的引入,我们开发了一个手机端的数据采集工具:CPUMonitor。原理如下:

工具具备以下几个特性:

1、广播作为工具驱动方式,方便应用于自动化脚本控制;

2、数据源取自系统:权威、详细;

3、多样的采集模式:频繁模式(freq)、触发模式(lazy)。

优势:

1、安装使用无权限要求;

2、可与电量测试同时进行;

3、数据取自系统保证准确性;

4、触发模式保证了最小性能消耗。

小结:目前,工具已经应用于多个移动端应用的电量测试中。除了可以高效定位电量问题外,还可以在功能开发前预估电量消耗,从产品层协助策略制定。通过自研工具的开发,有效的将原有的硬件测试方案替换成关注应用电量消耗的软件测试方案。自研工具获取的数据,全部来自于系统提供的接口,保证了数据的准确有效性。

Step4 提升效率

通过测试工具的开发,在一次电量测试过程中,已经能收集到帮助定位问题的足够详细的测试数据。所以,我们下一步需要思考的就是,如何能够更加高效更加精准的获取测试数据?
原有的电量测试流程:

存在的问题:

1、人工操作:设备连接、环境清理、应用安装、工具设置、初始数据采集;

2、人工操作:设备断开、场景操作执行、计时;

3、人工操作:设备连接、数据采集&保存。

人工干预每个环节导致:数据准确性低、执行效率低。

各环节的优化方案:

数据采集:脚本驱动+测试工具 替代 手动执行命令行;

操作执行:自动化脚本 替代 手工操作;

流程控制:PC控制 替代 人工控制。

优化后的电量测试流程:

解决需人工连接设备的问题:将传统的USB线中间增加硬件控制模块后,可由PC端的脚本控制硬件的断开连接。

解决USB连接断开后场景操作的执行问题:传统的解决方案:将自动化脚本放到手机端执行。

存在的问题:手机必须要有root权限。

解决的方案:adb无线控制,下发指令。

小结:通过全流程的自动化处理,减少人工干预,除了提高数据的准确性外,有效的提升了测试效率。以1小时待机电量测试为例,原测试流程和自动化测试流程相比较:

我们的收益

总结下我们在电量测试方面所做的工作:

1、通过对Android系统电量统计原理的分析,清晰的掌握到组成APP整体电量消耗的每一部分的消耗值,从而可以直接定位导致电量问题的大体方向。

2、通过测试工具的开发,获取到更加详细的功耗数据,从而可以直接定位到具体代码逻辑。

3、通过电量测试的自动化建设,有效提升测试效率,除了缩短测试时长、减少人力投入外,还提高了测试数据的准确性。

电量测试方案应用于移动终端产品,除了能快速检测定位电量问题外,还可以协助开发及产品评估新增功能带来的额外消耗。

通过一年多的工作,我们总结出一套理论与实践相结合的电量优化检测方法:

理论:在了解系统对应用电量统计原理的过程中,发现对wake lock消耗的计算在方法processAppUsage()中是没有进行条件判断的。也就是说,如果在亮屏时,代码逻辑中仍然注册了wake lock(测试的wake lock是没有任何意义的),在对应用进行电量统计时,就会计算上这部分的消耗:

在写代码时,可以注意下,在进行wake lock注册时,首先要判断手机的状态。

实践:在对多个应用进行电量测试的过程中,发现不同产品根据产品特性不同,除了共性导致电量异常的问题外,还会存在产品特性相关的操作场景。

我们抛开产品,抽离出共性问题,整理成下面这个表格:

在用例设计部分,我们将待机列为需要关注的场景,是因为用户对待机时应用的电量消耗更为敏感。而在这个场景下,经常会出现由于代码逻辑问题、产品策略问题导致应用电量消耗异常。在操作过程中的电量消耗,是用户预知的消耗。但如果使用不当,也会造成异常消耗。

想知道更多测试相关干货 请关注我们的微信公众号:腾讯移动品质中心TMQ。

TC264 主板温度过高可能由多种因素导致,以下是一些常见原因及相应的解决方法: ### 原因分析 1. **高负载运行** TC264 是一款高性能的微控制器主板,通常用于复杂的嵌入式系统和汽车电子应用。当其运行高强度任务时,CPU 和其他组件可能会产生大量热量[^3]。 2. **散热设计不足** 如果主板的散热设计不合理或散热器接触不良,可能导致热量无法有效散发,从而造成局部过热。 3. **环境温度过高** 数据中心或其他高温环境中,外部环境温度升高会直接影响主板的工作温度。例如,在数据中心中,冷却系统的温差设计不合理可能导致设备整体温度上升[^2]。 4. **电源管理问题** 不稳定的电源供应或电源模块效率低下也可能导致主板发热。如果主板上的稳压电路工作异常,可能会引起额外的功耗和发热。 5. **风扇或冷却系统故障** 若使用了主动冷却方案(如风扇),风扇故障或风道堵塞会导致冷却效果下降,使主板温度升高。 6. **硬件老化或损坏** 长时间运行后,主板上的某些元件可能出现老化或损坏,例如电容鼓包、芯片焊接点松动等,这些都可能导致异常发热。 --- ### 解决方法 1. **优化散热系统** - 检查散热器是否安装正确并与主板紧密接触。 - 可考虑更换更高性能的散热器或增加导热硅脂以提高热传导效率。 2. **改善通风与空气流动** - 确保主板所在环境有良好的空气流通。 - 清理灰尘,避免堵塞风道或影响风扇效率。 3. **降低负载** - 通过优化软件算法或减少并发任务来降低 CPU 负载。 - 合理安排任务调度,避免长时间高负载运行。 4. **检查电源系统** - 使用稳定可靠的电源适配器。 - 检查主板上的电源管理模块是否正常工作,必要时进行更换。 5. **监控温度并调整运行策略** - 利用主板自带的温度传感器或外接传感器实时监测温度。 - 在软件层面设置温度阈值,一旦超过安全范围自动降频或报警。 6. **定期维护与检测** - 定期检查主板元件是否有烧毁、鼓包或变色现象。 - 使用红外热像仪检测热点位置,及时处理异常发热区域。 --- ### 示例代码:读取主板温度传感器数据(假设使用 I²C 接口) ```c #include <Wire.h> #define TEMP_SENSOR_ADDRESS 0x48 // 假设温度传感器地址为 0x48 void setup() { Serial.begin(9600); Wire.begin(); } void loop() { int16_t rawTemp; float temperature; Wire.beginTransmission(TEMP_SENSOR_ADDRESS); Wire.write(0x00); // 选择温度寄存器 Wire.endTransmission(); Wire.requestFrom(TEMP_SENSOR_ADDRESS, 2); if (Wire.available() == 2) { rawTemp = (Wire.read() << 8) | Wire.read(); // 读取温度数据 temperature = rawTemp / 256.0; // 根据传感器手册转换 Serial.print("Temperature: "); Serial.print(temperature); Serial.println(" °C"); } delay(1000); // 每秒读取一次 } ``` --- ### 相关问题 1. 如何判断主板温度是否在安全范围内? 2. TC264 微控制器支持哪些温度监测接口? 3. 高温对主板电子元件有哪些长期影响? 4. 如何通过软件手段实现主板温度控制? 5. 散热器与导热硅脂如何选择才能提升散热效率?
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值