android高级进阶性能优化

android电量优化之Battery Historian工具使

2018-01-16  本文已影响139人  android的那点事

前几天写了关于androidAPP性能优化总结的文章,还没有看的话可以看一下,这文章提到了电量优化,android耗电分析所用到的工具battery-historian,这里做一个总结.

在 Android5.0 以前,在应用中测试电量消耗比较麻烦,也不准确,5.0 之后专门引入了一个获取设备上电量消耗信息的 API:Battery Historian。Battery Historian 是一款由 Google 提供的 Android 系统电量分析工具,是一款图形化数据分析工具,直观地展示出手机的电量消耗过程,通过输入电量分析文件,显示消耗情况,最后提供一些可供参考电量优化的方法。

数据准备

battery-historian工具需要使用bugreport中的Battery History

执行的效果如下:

image.png
上面的操作相当于初始化操作,如果不这么做会有一大堆的干扰的数据,看起来会比较痛苦。然后把数据线直接拔掉(防止数据线造成充放电数据干扰),现在做一些[测试],手动或者跑一些自动化的case都行。经过一段时间后,我们重新连接手机确认adb连上了,运行下面这条命令来将bugreport的信息保存到txt文档中,
adb bugreport> bugreport.txt

或者用下面的命令也可以:

adb shell dumpsysbatterystats> batterystats.txt
adb shell dumpsysbatterystats>com.example.android.sunshine.app> batterystats.txt

加上包名可以限制输出的数据是我们要检测的。
但是这个txt的数据可读性不强。接下来我们就要用到这个battery-historian工具了。

到此我们有两种方式分析这个文件:(historian-V1之前的版本和historian-V2最新的版本)

historian-V1之前的版本分析方式:

将txt文档转化为html文件,命令如下。

python historian.py -a bugreport.txt> battery.html

上面的historian.py脚本是Python写的,所以需要python环境,然后从github上下载这个脚本。文件在github上面的scripts目录下面,需要下载到命令行所在的目录

image.png

上面两条命令执行成功后,会在目录下发现两个文件
bugreport.txt和battery.html,这个时候我们用google浏览器打开html文件,可以看到如下信息:


image.png
各个参数的意义

首先我们在bugreport.txt找到Battery History数据栏类似下面的信息:

  -------------------------------------------------------------------------------

  DUMPOFSERVICEbatterystats:

  BatteryHistory (2% used, 5980 used of256KB, 45 strings using 2592):

  0 (9) RESET:TIME: 2015-03-05-15-21-56

  0 (2) 100 c0900422 status=discharging health=good plug=none temp=200       volt=4167 +running +wake_lock +sensor +screen data_conn=edge phone_signal_strength=great brightness=medium proc=u0a15:"android.process.acore"

  0 (2) 100 c0900422 proc=u0a7:"com.android.cellbroadcastreceiver"

  0 (2) 100 c0900422 proc=u0a53:"com.android.gallery3d"

你在html中信息都能从bugreport.txt中找到相应的信息。

现在来分析各个指标代表的意义:

上面的10,20代表的就是秒的意思,它是以一分钟为周期,到第60秒的时候变为0。横坐标就是一个时间范围,咱们的例子中统计的数据是以重置为起点,获取bugreport内容时刻为终点。我们一共采集了多长时间的数据,图表下也有信息说明。(经其他人的反馈,这个坐标间隔是会随着时间的长度发生改变,所以要以你的实际情况为准。这个缩放级别可以调整的,如下图:)

image.png image.png

historian-V2最新的版本的方式:

将生成bugreport.txt文件在 [http://localhost:9999](javascript:goto();) 中上传文件生成报告(前提在本地或者某服务器上搭好了battery-historian项目环境

image.png

其实在这里也可以看到两种版本分析模式:

image.png

好了,battery-historian分析工具就写到这里,大家有兴趣的话可以去试试!

本人做android开发多年,以后会陆续更新关于android高级UI,NDK开发,性能优化等文章,更多请关注我的微信公众号:谢谢!
android的那点事.jpg
上一篇 下一篇

猜你喜欢

热点阅读