Android系统新特性——功耗的改进

移动设备的续航时间无疑是所有用户都非常在意的。我们都希望自己的手机一次充电可以使用更长的时间。但遗憾的是,近几年移动设备的电池元件一直没有重大的技术突破。并且,随着硬件性能的提升却带来了更多的电量消耗。
如果对比近几年的Android和ios手机,我们会发现:通常情况下,Android手机的电池要比同时期的ios电池容量大很多,但是待机方面却没有太大的优势。ios之所以续航优秀,其很大的原因在于对于后台进程的限制。在ios上,后台进程是无法长时间处于活跃状态的。而Android系统正好相反,通过监听广播、添加后台服务等方式,应用程序可以一直在后台保持活跃。太多进程的长时间活跃,显然会导致电量的快速耗尽。而反过来,想要延长电池寿命的重要措施就是尽可能减少后台应用的活跃性。因此,从Android5.0到8.0的功耗改进,一直都是围绕着“后台进程的活跃性”来展开的。

Project Volta

project volta是在Android5上引入的。要延长电池的寿命,首先就得要明确消耗电量的主要因素是什么。在移动设备上,对于电量的消耗最大的是下面三个模块:

  • 应用处理器(CPU、GPU)
  • 电话信号
  • 屏幕

除此之外,设备的频繁唤醒也会导致电量消耗过快。系统唤醒1s所消耗的电量约等于两分钟系统待机所消耗的电量。如果系统中安装了大量的应用,每个应用都在不同的时间点将系统唤醒(例如,通过广播或者服务),那么无疑会导致电量很快耗尽。
反过来,假设系统能将应用唤醒系统的频率减低,尽可能将不同应用唤醒系统的步调合并和集中,便能减少电量的消耗。

为了改善电池使用寿命,project volta提供的机制包含以下几个方面:

  • 提供了JobScheduler API
    Android5新增了该api,这个api允许开发者定义一些系统在稍后或指定条件下(如设备充电时)以异步方式运行的作业,从而优化电池寿命。下列情形下,这个功能很有用:

    • 应用具有不面向用户并且可以推迟的作业
    • 应用具有在设备插入电源时再进行的作业
    • 应用具有一项需要接入网络或连接wlan的任务
    • 应用具有多项希望定期以批处理方式运行的任务

参考资料: https://blog.csdn.net/FightFightFight/article/details/86240553

  • 提供工具帮助开发者发现问题
    为了帮助开发者分析系统的电池消耗,Android系统内置了Batterystats工具。可以通过下面的命令来使用这个工具:

    adb shell dumpsys batterystats

这个命令的输出内容非常长,人工阅读比较困难。所以Google提供了另一款工具,可以将上一步的输出装换成图形的方式方便解读。https://github.com/google/battery-historian

通过这两个工具的组合,可以得到一份图形化的电量信息的报表。
整个过程操作步骤如下:

  1. 从https://github.com/google/battery-historian下载工具。
  2. 解压缩刚刚下载的压缩包,并找到historian.py脚本。
  3. 将设备连接到pc上。
  4. 打开一个终端。
  5. 通过cd命令切换到historian.py脚本所在路径。
  6. 停止adb server:adb kill-server。
  7. 重启adb服务并通过adb devices确认设备已经连接上。
  8. 重置电磁使用历史数据:adb shell dumpsys batterystats–reset。
  9. 将设备与pc断开连接。
  10. 正常使用待测试的应用程序。
  11. 重新将设备与pc连接。
  12. 通过adb devices确认设备已经连接成功。
  13. 通过adb shell dumpsys batterystats>batterystats.txt将电池统计结果导出到文本文件中。
  14. 通过python historian.py batterystats.txt>batterystats.html获取图形化结果。
  15. 通过浏览器打开batterystats.html。
  16. 对结果进行分析。
  • 在虚拟机层面减少电池消耗
    Android5之前的版本使用的是Dalvik虚拟机,Android5及其之后的版本正式使用了新的虚拟机:ART。Dalvik虚拟机上解释执行和JIT,是在应用程序每次运行过程中将java字节码翻译为机器码的,这个翻译过程可能是反复的、多次的。而art上的aot是在应用安装的时候,一次性直接将字节码编译成了机器码(虽然说art后来的版本改进,没有一次性将所有代码编译为机器码,但总的来说,无论是安装时,还是后期运行时,只要有过一次编译成机器码,之后就不再重复编译了)。从字节码到机器码这个过程本身就非常消耗cpu,因此也是非常耗电的。而art虚拟机的引入和改进,由运行多次翻译改成一次编译。节省了cpu的执行,也节省了电量的消耗。
  • 提供省电模式给用户
    Android5上添加了一个新的省电模式给用户,用户可以通过系统设置主动打开省电模式,也可以设置电量过低时自动打开。

Doze模式与App StandBy

Project Volta主要是提供了一些api和工具给开发者,让开发者配合来改善电池寿命,所以这个机制的效果很难得到保证。从Android6开始,系统包含了一些自动的省电行为,这些行为对系统上的所有应用都会产生影响,不需要开发者做特殊适配。

从Android6开始,Android引入了两个新的省电功能为用户延长电池寿命。

  • Doze:该模式的运行机制是系统会监测设备的活跃状态,如果设备长时间处于闲置状态且没有接入电源,那么便推迟应用的后台cpu和网络活动来减少电池消耗。
  • App StandBy:该模式可推迟用户近期未与之交互的应用的后台网络活动。

Doze模式和AppStandBy会影响Android6或更高版本上运行的所有应用,无论它们是否特别设置过api level。

了解Doze模式

如果用户设备未接入电源、处于静止状态一段时间且屏幕关闭,设备便会进入Doze模式。在Doze模式下,系统会尝试通过限制应用对网络和cpu密集型服务的访问来节省电量。
系统会定期退出Doze模式一会,好让应用完成其已推迟的活动。在此维护时段内,系统会运行所有待定同步、作业和闹钟并允许应用访问网络。在每个维护时段结束后,系统会再次进入Doze模式,暂停网络访问并推迟作业、同步和闹铃。随着时间的推移,系统安排维护时段的次数越来越少,这有助于在设备未连接至充电器的情况下长期处于不活跃状态时降低电池消耗。
一旦用户通过移动设备、打开屏幕或连接到充电器唤醒设备,系统就会立即退出Doze模式,并且所有应用都将返回到正常活动状态。

Android6.0引入了Doze模式,当用户设备未插入电源、处于静止状态且屏幕关闭时,该模式会推迟cpu和网络活动,从而延长电池寿命。而Android7.0则通过在设备未插接电源且屏幕关闭状态下,但不一定要处于静止状态(例如,用户外出时把手持式设备装在口袋里)时应用部分cpu和网络限制,进一步增强了Doze模式。

当设备处于充电状态且屏幕已关闭一定时间后,设备会进入Doze模式并应用第一部分限制:关闭应用网络访问,推迟作业和同步。如果进入Doze模式后设备处于静止状态且达到一定时间,系统则会对PowerManager.WakeLock、AlarmManager闹铃、GPS和WLAN扫描应用余下的Doze模式限制。无论是应用部分还是全部Doze模式限制,系统都会唤醒设备以提供简短的维护时间窗口,在此窗口期间,应用程序可以访问网络并执行任何被推迟的作业/同步。同样,一旦激活屏幕或插接设备电源,系统将退出Doze模式并移除这些处理限制。

了解App StandBy

App StandBy允许系统判定应用在用户未主动使用它时使其处于空闲状态。当用户有一段时间未触摸应用时,系统便会做出此判定。但是对于以下情况,系统将判定应用退出App StandBy状态,包括:

  • 用户显示启动应用
  • 应用有一个前台进程(例如activity或前台服务,或被另一个activity或前台服务使用)
  • 应用生成用户可在锁屏或通知栏中看到的通知

当用户将设备插入电源时,系统将从App StandBy状态释放应用,从而让它们可以自由访问网络并执行任何特定作业和同步。如果设备长时间处于空闲状态,系统将按每天大约一次的频率允许该应用访问网络。

通过妥善管理网络连接、闹钟、作业和同步并使用FCM高优先级消息,几乎所有应用都应该能够支持Doze模式。对于一小部分用例,这可能还不够。对于此类用例,系统为部分免除Doze模式和App StandBy优化的应用提供了一份可配置的白名单。
在Doze模式和App StandBy期间,加入白名单的应用可以使用网络并保留部分wake locks。不过,正如其他应用一样,其他限制仍然适用于加入白名单的应用。例如,加入白名单的原因的作业和同步将推迟,并且其常规alarmmanager闹铃不会触发。通过调用isIgnoringBatteryOptimizations(),应用可以检查自身当前是否位于白名单中。
用户可以在Settings->Battery->Battery optimization中手动配置该白名单。
另外,系统也为应用提供了编程接口来请求让用户将其加入白名单。

  • 应用可以触发Settings.ACTION_IGNORE_BATTERY_OPTIMIZATION_SETTINGS的Intent,让用户直接进入电池优化界面,他们可以在其中添加应用。
  • 具有REQUEST_IGNORE_BATTERY_OPTIMIZATIONS权限的应用可以触发系统对话框,让用户无须转到“设置”即可直接将应用添加到白名单。应用将通过触发Settings.ACTION_IGNORE_BATTERY_OPTIMIZATION_SETTINGS的Intent来触发该对话框。
  • 用户可以根据需要手动从白名单中移除应用。

在这里插入图片描述

Android8.0上的后台限制

Android6.0和7.0两个版本提供了Project Volta、Doze模式以及App StandBy机制来降低功耗以延长电池寿命。
但实际上Android系统上最令人诟病的“后台问题‘仍然没有得到解决:应用程序很容易通过监听各种广播的方式来启动后台服务,然后长时间在后台保持活跃。这样做无疑会导致电池电量很快耗尽。Android系统的用户对此应该深有体会,通过系统设置中额运行中应用列表,总能看到一大串的服务在后台运行着。

概览

Android是一个多任务的os。例如,用户可以在一个窗口中玩游戏,同时在另一个窗口中浏览网页,并使用第三个应用播放音乐。
同时运行的应用越多,对系统造成的负担越大。如果还有应用或服务在后台运行,会对系统造成更大负担,进而可能导致用户体验下降。例如,音乐应用可能会突然关闭。
为了减低发生这些问题的概率,Android8.0对应用在用户不与其直接交互时可以执行的操作施加了限制。

应用在两个方面受到限制:

  • 后台服务限制:处于空闲状态时,应用可以使用的后台服务存在限制,但这些限制不实施于前台服务,因为前台服务更容易引起用户注意。

  • 广播限制:除了有限的例外情况,应用无法使用AndroidManife.xml注册隐式广播。但它们仍然可以在运行时注册这些广播,并且可以使用AndroidManifest.xml注册专门针对它们的显式广播。

    默认情况下,这些限制仅适用于针对8.0的应用。不过,用户可以从Settings屏幕为任意应用启用这些限制,即使应用并不是以8.0为目标平台。

后台服务限制

在后台中运行的服务会消耗设备资源,这可能会降低用户体验。为了缓解这一问题,系统对这些服务施加了一些限制。
如果满足以下条件中的任意一个,应用都将被视为处于前台:

  • 具有可见activity,不管该activity处于resume还是pause状态
  • 具有前台服务
  • 另一个前台应用关联到当前应用,可能是绑定到其中一个service,或者是使用其中一个contentprovider。

如果以上条件均不满足,则应用被视为处于后台。
处于前台时,应用可以自由创建和运行前台服务和后台服务。进入后台时,在一个持续数分钟的时间窗内,应用仍可以创建和使用服务。
在该时间窗结束后,应用将被视为处于空闲状态。此时,系统将停止应用的后台服务,就像应用已经调用服务的stopself()方法。

在下面这些情况下,后台应用将被置于一个临时白名单中并持续数分钟。位于白名单中时,应用可以无限制地启动服务,并且其后台服务也可以运行。

处理对用户可见地任务时,应用将被置于白名单中,例如:

  • 处理一条高优先级fcm云消息。
  • 接收广播,例如,短信/彩信。
  • 从通知中执行pendingintent。

在很多情况下,应用都可以使用JobScheduler来替换后台服务。在Android8.0之前,创建前台服务的方式通常时先创建一个后台服务,然后将该服务推到前台。Android8.0有一项复杂功能:系统不允许后台应用创建后台服务。因此,Android8.0引入了一个权全新的方法,即Context.startForegroundService(),以在前台启动新服务。在系统创建服务后,应用有5s的时间来调用该服务的startForeground方法以显示新服务的用户可见通知。如果应用在此时间限制内未调用该方法,则会报anr的错误。

广播限制

如果应用注册为接收广播,则在每次发送广播时,应用的接收器都会消耗资源。如果多个应用注册为接收基于系统事件的广播,这会引发问题:触发广播的系统事件会导致所有应用快速地连续消耗资源,从而降低用户体验。
为了缓解这一问题,Android7.0对广播施加了一些限制,而Android8.0让这些限制更为严格。

  • Android8.0的应用无法继续在其AndroidManifest.xml中为隐式广播注册广播接收器。隐式广播是一种不专门针对该应用的广播,它将发送到注册的所有侦听器中。
  • 应用可以继续在它们的清单中注册显式广播。
  • 应用可以在运行时使用registerReceiver动态地为任意广播(不管是隐式还是显式)注册接收器。
  • 需要签名权限地广播不受此限制所限,因为这些广播只会发送到使用相同证书签名地应用,而不是发送到设备上地所有应用。
  • 在Android8.0版本上,系统对应用程序的后台位置也进行了限制:为降低功耗,无论应用的目标sdk版本是什么,Android8.0都会对后台应用检索用户当前位置的频率进行限制。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

3. 迷宫问题

题目 迷宫有一个入口,一个出口。一个人从入口走进迷宫,目标是找到出口。阴影部分和迷宫的外框为墙,每一步走一格,每格有四个可走的方向,探索顺序为地图方向:南(下)、东(右…

概率论与数理统计中常见的随机变量分布律、数学期望、方差及其介绍

1 离散型随机变量 1.1 0-1分布 设随机变量X的所有可能取值为0与1两个值,其分布律为 若分布律如上所示,则称X服从以P为参数的(0-1)分布或两点分布。记作X~ B(1,p) 0-1分布的分布律利用表格法表示为: X01P1-PP 0-1分布的数学期望E(X) 0 *…

关于反射、枚举以及Lambda表达式你了解多少呢?快来看看吧~

目录 1、反射 1.1、定义 1.2、用途 1.3、反射基本信息 1.4、反射相关的类【重点】 1.5、Class类(反射机制的起源) 1.6、Class类中相关的方法 1.7、获得Class对象的三种方式 1.8、反射的使用 1.9、反射的优点、缺点 2、枚举 2.1、背景及定义 …

【代码随想录刷题】Day18 二叉树05

文章目录 1.【513】找树左下角的值1.1题目描述1.2 解题思路1.2.1 迭代法思路1.2.2 递归法思路 1.3 java代码实现1.3.1 迭代法java代码实现1.3.2 递归法java代码实现 2. 【112】路径总和2.1题目描述2.2 解题思路2.3 java代码实现 3.【106】从中序与后序遍历序列构造二叉树3.1题目…

6.前端--CSS-基础选择器【2023.11.26】

1.CSS基本选择器 标签选择器&#xff1a; 标签选择器&#xff08;元素选择器&#xff09;是指用 HTML 标签名称作为选择器&#xff0c;按标签名称分类&#xff0c;为页面中某一类标签指定统一的 CSS 样式。标签选择器可以把某一类标签全部选择出来&#xff0c;比如所有的 <…

js原理网页内容防复制-原理、实现及破解

大家好&#xff0c;这一集我们来看一下如何通过js代码实现网页内容防复制&#xff0c;并且使用代码复现效果&#xff0c;同时如何破解这种防复制。 视频教程链接&#xff1a;https://www.bilibili.com/video/BV1zM41197y7/ 代码删掉即可&#xff0c;删不掉关闭设置 您可以使用…

基于STC12C5A60S2系列1T 8051单片按页写IIC总线器件24C02并显示在液晶显示器LCD1602上应用

基于STC12C5A60S2系列1T 8051单片机按页写IIC总线器件24C02并显示在液晶显示器LCD1602上应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍液晶显示器LCD1602简单介绍…

Android设计模式--桥接模式

闻正言&#xff0c;行正道&#xff0c;左右前后皆正人 一&#xff0c;定义 将抽象部分与实现部分分离&#xff0c;使它们都可以独立地进行变化 二&#xff0c;使用场景 从模式的定义中&#xff0c;我们大致可以了解到&#xff0c;这里的桥接的作用其实就是连接抽象部分与实现…

DDD落地:从阿里单据系统,看DDD在大厂如何落地?

尼恩说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试资格&#xff0c;遇到很多很重要的面试题&#xff1a; 谈谈你的DDD落地经验&#xff1f; 谈谈你对DDD的理解&#x…

【libGDX】Mesh立方体贴图(6张图)

1 前言 本文通过一个立方体贴图的例子&#xff0c;讲解三维纹理贴图的应用&#xff0c;案例中使用 6 张不同的图片给立方体贴图&#xff0c;图片如下。 读者如果对 libGDX 不太熟悉&#xff0c;请回顾以下内容。 使用Mesh绘制三角形使用Mesh绘制矩形使用Mesh绘制圆形使用Mesh绘…

原生DOM事件、react16、17和Vue合成事件

目录 原生DOM事件 注册/绑定事件 按DOM事件级别分类&#xff0c;越小越高 DOM0&#xff1a;onclick传统注册&#xff1a; 唯一&#xff08;同元素的(不)同事件会覆盖&#xff09; 没有捕获和冒泡的&#xff0c;只有简单的事件绑定 DOM2&#xff1a;addEventListener监听…

Mybatis反射核心类Reflector

Reflector类负责对一个类进行反射解析&#xff0c;并将解析后的结果在属性中存储起来。 一个类反射解析后都有哪些属性呢&#xff1f;我们可以通过Reflector类定义的属性来查看 public class Reflector {// 要被反射解析的类private final Class<?> type;// 可读属性列…

【聚类 | K-means】原理及推导流程(附模板代码,库手撕实现)

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

shell脚本 ( 函数 数组 冒泡排序)

目录 什么是函数 使用函数的方法 格式 注意事项 函数的使用 函数可以直接使用 函数变量的作用范围 函数返回值 查看函数 删除函数 函数的传递参数 使用函数文件 ​编辑 拓展递归函数 例&#xff1a;求5的阶乘 什么是数组 使用数组的方法 1.先声明 2.定义数组 3…

MQTT客户端MQTT.fx 1.7.1下载、安装和界面介绍

MQTT.fx是一款基于Eclipse Paho&#xff0c;使用Java语言编写的MQTT客户端工具。支持通过Topic订阅和发布消息&#xff0c;用来前期和物理云平台调试非常方便。 1.下载 1.1.访问官方下载地址下载&#xff0c;但是下载不到1.7.1版本 1.2.在连接网页末尾点击立即下载&#xff0c;…

思维模型 古烈治效应

本系列文章 主要是 分享 思维模型&#xff0c;涉及各个领域&#xff0c;重在提升认知。见异思迁。 1 古烈治效应的应用 1.1 古烈治效应之心理学研究 在一项研究中&#xff0c;研究者让男性和女性参与者分别观看一系列异性的照片&#xff0c;并评估他们的吸引力。在观看完所有…

(三) Windows 下 Sublime Text 3 配置Python环境和Anaconda代码提示

一&#xff1a;新建一个 Python3.7 编译环境。 1 Tools--Build System--New Build System... 修改前&#xff1a; 修改后&#xff1a; 内容&#xff1a; {"cmd":["C:\\Python\\Python37-32\\python.exe","-u","$file"],"file_r…

Java基于springboot+vue开发服装商城小程序

演示视频&#xff1a; 小程序 https://www.bilibili.com/video/BV1rM411o7m4/?share_sourcecopy_web&vd_source11344bb73ef9b33550b8202d07ae139b 管理员 https://www.bilibili.com/video/BV1fc411D7V3/?share_sourcecopy_web&vd_source11344bb73ef9b33550b8202d07ae…

CV计算机视觉每日开源代码Paper with code速览-2023.11.21

点击CV计算机视觉&#xff0c;关注更多CV干货 论文已打包&#xff0c;点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构&#xff1a;Transformer】Multi-entity Video Transformers for Fine-Grained Video Representation Learning 论文地址&…

WordPress最廉价优化整站的加载速度

为什么说一个站不优化就等于一个人做整个团队的事务导致项目进展慢&#xff0c;网站也是如此 图片、静态文件、php分离加速&#xff0c;加载速度并不是很快但是很协调比单个网站加载速度快许多 一、图片单域名加载设置上传文件路径和域名 以下代码添加在主题目录&#xff1a;fu…