【Android】性能优化:电量消耗统计

栏目: IOS · Android · 发布时间: 6年前

内容简介:电量的消耗和使用对于移动设备非常重要,一项从硬件的角度看,Android电量的消耗主要来自屏幕,CPU,网络设备和各样的传感器:指纹,亮度,温湿度,陀螺仪,加速器等等。通常情况下,屏幕是耗电量最大的模式。一般来讲,Android设备的屏幕主要分为两种:

电量的消耗和使用对于移动设备非常重要,一项 调查问卷 显示,电池的容量和寿命是手机最重要的营销点:所谓“the one thing that you can't do without”。

【Android】性能优化:电量消耗统计

硬件

从硬件的角度看,Android电量的消耗主要来自屏幕,CPU,网络设备和各样的传感器:指纹,亮度,温湿度,陀螺仪,加速器等等。通常情况下,屏幕是耗电量最大的模式。一般来讲,Android设备的屏幕主要分为两种: Liquid-crystal display (LCD)Light-emitting diode (LED) :

  • LCD 有很多个液晶分子来负责每个像素的显示,然后由一个背光将所有的液晶分子同时照亮。每个像素的能耗是相同的,与呈现的颜色无关。

【Android】性能优化:电量消耗统计

  • LED 则是自发光:每个像素点由红、蓝、绿三种颜色光源的发光二极管共同控制和呈现。黑色不使用任何颜色,所以可以认为是无能耗,而白色需要所有的光源,耗能最多。所以有些手机在省电模式下(比如华为的超级省电模式),手机的背景都会设置成黑色。

【Android】性能优化:电量消耗统计

LEDLCD 的功耗比大约为1:10, LED 更节能。同时 LED 在刷新率,鲜艳度和饱和度方面效果也更好,可以制造出比 LCD 更薄、更亮、更清晰的显示器。所以现在市面上的智能机大部分为 LED 屏。

除了屏幕之外,比较明显的耗电硬件是wifi或者数据网络连接设备,以及GPS定位。一般情况,使用wifi的能耗要小于使用移动网络的能耗。

另外还有CPU。一定情况下,CPU的耗电量可能是最大的,比如我们玩游戏的时候会明显感觉手机发烫,电量急速下掉。

耗电统计

可以使用adb dump来得到设备的能耗统计(batterystats)。首先重置手机状态:

adb shell dumpsys batterystats --reset
adb shell dumpsys batterystats --enable full-wake-history

拔掉usb连接(避免充电),随意进行一定操作之后,采集能耗数据:

adb shell dumpsys batterystats > battery.txt

可以得到每个进程(Uid)的WakeLock以及所有app的能耗清单。

Battery History (1% used, 6456 used of 512KB, 115 strings using 8706):
                    0 (10) RESET:TIME: 2018-12-02-21-59-12
                    0 (2) 100 status=discharging health=good plug=none temp=286 volt=4388 charge=3574 +running +wake_lock +screen phone_signal_strength=great brightness=medium +usb_data wifi_signal_strength=4 wifi_suppl=completed proc=u0a99:"com.google.android.apps.turbo"
                    0 (2) 100 proc=u0a83:"com.android.printspooler"
                    0 (2) 100 proc=u0a20:"com.google.android.setupwizard"
                    0 (2) 100 proc=1000:"com.google.SSRestartDetector"
                    0 (2) 100 proc=u0a167:"com.tencent.mm"
                    0 (2) 100 proc=u0a171:"com.touchtype.swiftkey"
...

Google的 Battery Historian 可以帮助我们更直观的分析这些数据。 battery-historian/scripts/ 有Battery Historian的第一版,用起来比较简单(需要有 Python 环境):

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

打开生成的battery.html文件可以看到具体的耗电情况。

【Android】性能优化:电量消耗统计

一些简单的示意:

  • 横坐标:时间
  • battery_level:剩余电量
  • plugged:设备是否连接电源
  • screen:屏幕开启时长
  • top:当前屏幕显示的进程,比如上图中的进程com.tencent.mm就是微信
  • wake_lock*:wake_lock模块的工作时长
  • running:界面状态,主要为是否处于idle的状态。可以协助统计应用
  • wake_lock_in: 模块开始工作的时间以及时长
  • job:后台job
  • conn:网络连接方式,wifi或者2G,3G等
  • power_save:应该是省电模式开始时长吧,可能Android P之后才有的

historian.py是 Battery Historian 的第一版,而用 Go 重写的第二版更为强大,可以将耗电统计精确到每个进程。 Battery Historian 2.0 在9999端口挂在了一个分析和转换数据格式的服务器,比较简单的方法是通过 Docker 容器引擎,需要先安装 Docker 。运行:

docker run hello-world

看到如下输出就证明安装成功啦:

Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
78445dd45222: Pull complete
Digest:
sha256:c5515758d4c5e1e838e9cd307f6c6a0d620b5e07e6f927b07d05f6d12a1ac8d7
Status: Downloaded newer image for hello-world:latest
...

启动Battery Historain镜像:

docker -- run -p <port>:9999 gcr.io/android-battery-historian/:3.0 --port 9999

其中<port>为你的端口号,比如:

docker -- run -p 2222:9999 gcr.io/android-battery-historian/:3.0 --port 9999

如果遇到下面的错误:

Unable to find image 'gcr.io/android-battery-historian:3.0' locally
docker: Error response from daemon: manifest for gcr.io/android-battery-historian:3.0 not found.
See 'docker run --help'.

可以尝试sudo或者stable版:

docker -- run -p 2222:9999 gcr.io/android-battery-historian/stable:3.0 --port 9999

运行成功后在http://localhost/2222 就可以上传你的bugreport来分析了。生成bugreport:

adb bugreport > bugreport.zip

将bugreport.zip上传到http://localhost/2222,就可以看到详细的耗电统计报告:

【Android】性能优化:电量消耗统计

Historain V2非常强大,可以看到每个App的耗电情况,比如微信:

【Android】性能优化:电量消耗统计

资料

  • https://developer.android.com/studio/profile/battery-historian
  • https://github.com/google/battery-historian
  • https://docs.docker.com/install/
  • https://www.phonearena.com/news/What-is-the-most-important-smartphone-feature-to-you_id103392
  • https://en.wikipedia.org/wiki/Light-emitting_diode
  • https://en.wikipedia.org/wiki/Liquid-crystal_display 

(转载请注明作者和出处:http://blog.csdn.net/xiaowei_cqu 未经允许请勿用于商业用途)

扫描或搜索公众号: 小魏的修行路 ,在手机端查看文章

【Android】性能优化:电量消耗统计


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

MacTalk 人生元编程

MacTalk 人生元编程

池建强 / 人民邮电出版社 / 2014-2-1 / 45

《MacTalk·人生元编程》是一本随笔文集,主要内容来自作者的微信公众平台“MacTalk By 池建强”。本书撰写于2013年,书中时间线却不止于此。作者以一个70 后程序员的笔触,立于Mac 之上,讲述技术与人文的故事,有历史,有明天,有技术,有人生。70 多篇文章划分为六大主题:Mac、程序员与编程、科技与人文、人物、工具、职场。篇篇独立成文,可拆可合,随时阅读。 此外,作者还对原来......一起来看看 《MacTalk 人生元编程》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具