小酌鸡汤
纸上得来终觉浅,绝知此事要躬行。
本文来源《Android 性能优化 全家桶》
为什么要优化应用消耗电池电量?
手机在屏幕唤醒,cpu唤醒,网络,定位等耗电严重,如果应用在非必要场景依然使用的话,很容易造成耗电严重,手机发烫等现象。当然也会遭到用户无情的抛弃……
为什么要用 energy profiler?
- Energy Profiler 可帮助您了解应用在哪里耗用了不必要的电量。
- Energy Profiler 会监控 CPU、网络无线装置和 GPS 传感器的使用情况,并直观地显示其中每个组件消耗的电量。Energy Profiler 还会显示可能会影响耗电量的系统事件(唤醒锁定、闹钟、作业和位置信息请求)的发生次数。
- Energy Profiler 并不会直接测量耗电量,而是使用一种模型来估算设备上每项资源的耗电量。
- 借助 Energy Profiler,您可以轻松找到应用使用各项功能的位置,以便您就如何使用各项功能做出明智的决策。
现在,就一起实操体验profiler吧!
(1)profiler实操环境(可选项,用自己的环境和代码也一样)
- SamplePop代码下载
- SamplePop环境如下:
Android Studio 4.0
Gradle version 6.1.1
Android API version 30
(2)打开profiler
- profiler打开位置:View -> Tool Windows -> Profiler
- 当然也可以直接运行程序并启用profiler监控:Run -> Profiler
(3)来吧,一起预览一下吧:
profiler概览(4)点击ENERGY分类栏,就可以进入到energy profiler详情页:
energy-profiler详情页概览窗口详细说明:
- 窗口1:性能分类切换按钮,包括:cpu、memeory、network、energy。
- 窗口2:页面调整按钮集合,包括:缩小,放大、重置、暂停、开始等。
- 窗口3:事件时间轴,显示Activity的生命周期不同状态,用户交互事件,如点击,旋转等。
- 窗口4:显示应用的估算耗电量(要查看 CPU、网络和位置信息 (GPS) 资源,以及相关系统事件的具体耗电量情况,请将鼠标指针放在 Energy 时间轴中的条形上方):
CPU:cpu工作损耗电量
Network:网络通信损耗电量
Location:定位功能损耗电量
(5)随时查看电量损耗情况(在时间轴上拖动以选择要查看的区域):
energy-profiler选取片段查看对各个窗口进行说明:
- 1.事件时间轴:可以拖动选择想分析的数据部分。
- 2.系统事件时间轴:显示可能会影响耗电量的系统事件,每一条事件都会显示一个彩色编码的条形,以表示系统事件处于活动状态的时间范围。条形的不同颜色表示不同类别的系统事件:
红色:唤醒锁定
黄色:作业和闹钟
浅紫色:位置信息 - 3.系统事件详情:双击调用堆栈顶部的调用方法条目,跳转到唤醒锁定的源代码。
对上面所提到的系统事件做说明:
- WakeLock(唤醒锁定):是一种机制,可在设备进入休眠模式时使 CPU 或屏幕保持开启状态。例如,播放视频的应用可以使用唤醒锁定,以便在用户未与设备交互时使屏幕保持开启状态。请求唤醒锁定不是一项耗电量很高的操作,但未撤消唤醒锁定会导致屏幕或 CPU 保持开启状态的时间超过必要时间,从而加快电池耗电速度。
- Alarms(闹钟):您可以使用闹钟定期在应用上下文之外运行后台任务。当闹钟触发时,它可能会唤醒设备并运行耗电量很高的代码。
-
Jobs(作业):您可以使用作业在指定条件下(例如恢复网络连接时)执行相关操作。您可以使用
JobBuilder
创建作业,并使用JobScheduler
对这些作业进行调度。在许多情况下,建议您使用JobScheduler
对作业进行调度,而不是使用闹钟或唤醒锁定。 - Location(位置):位置信息请求使用 GPS 传感器,这会消耗大量电量。
(六)SamplePop示例代码:
public class EnergyProfilerActivity extends AppCompatActivity {
private static final String TAG = "EnergyProfilerActivity";
private PowerManager.WakeLock mWakeLock;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_energy_profiler);
}
public void onEnergyWakeLockAcquire(View view) {
Log.d(TAG, "onEnergyWakeLockTest: ");
if (mWakeLock != null) {
return;
}
createWakeLock();
mWakeLock.acquire();
}
public void onEnergyWakeLockRelease(View view) {
Log.d(TAG, "onEnergyWakeLockRelease: ");
if (mWakeLock != null) {
mWakeLock.release();
mWakeLock = null;
}
}
private void createWakeLock() {
Log.d(TAG, "createWakeLock: ");
PowerManager pm = (PowerManager) getBaseContext().getSystemService(POWER_SERVICE);
mWakeLock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, getClass().getSimpleName());
}
}
小编的扩展链接
参考链接
会当凌绝顶,一览众山小
举手之劳,赞有余香! ❤ 比心 ❤
网友评论