android profiler 简书,(四)Android 性能优化 Energy Profiler

 2023-09-10 阅读 25 评论 0

摘要:小酌鸡汤纸上得来终觉浅,绝知此事要躬行。android recyclerview缓存机制、为什么要优化应用消耗电池电量?手机在屏幕唤醒,cpu唤醒,网络,定位等耗电严重,如果应用在非必要场景依然使用的话,很容易造成耗电严重,手机发

小酌鸡汤

纸上得来终觉浅,绝知此事要躬行。

android recyclerview缓存机制、为什么要优化应用消耗电池电量?

手机在屏幕唤醒,cpu唤醒,网络,定位等耗电严重,如果应用在非必要场景依然使用的话,很容易造成耗电严重,手机发烫等现象。当然也会遭到用户无情的抛弃……

为什么要用 energy profiler?

android?Energy Profiler 可帮助您了解应用在哪里耗用了不必要的电量。

Energy Profiler 会监控 CPU、网络无线装置和 GPS 传感器的使用情况,并直观地显示其中每个组件消耗的电量。Energy Profiler 还会显示可能会影响耗电量的系统事件(唤醒锁定、闹钟、作业和位置信息请求)的发生次数。

Energy Profiler 并不会直接测量耗电量,而是使用一种模型来估算设备上每项资源的耗电量。

android性能优化和内存优化、借助 Energy Profiler,您可以轻松找到应用使用各项功能的位置,以便您就如何使用各项功能做出明智的决策。

现在,就一起实操体验profiler吧!

(1)profiler实操环境(可选项,用自己的环境和代码也一样)

android 性能优化。SamplePop环境如下:

Android Studio 4.0

Gradle version 6.1.1

android内存优化。Android API version 30

(2)打开profiler

profiler打开位置:View -> Tool Windows -> Profiler

当然也可以直接运行程序并启用profiler监控:Run -> Profiler

(3)来吧,一起预览一下吧:

0f1313c25d31

profiler概览

(4)点击ENERGY分类栏,就可以进入到energy profiler详情页:

0f1313c25d31

energy-profiler详情页概览

窗口详细说明:

窗口1:性能分类切换按钮,包括:cpu、memeory、network、energy。

窗口2:页面调整按钮集合,包括:缩小,放大、重置、暂停、开始等。

窗口3:事件时间轴,显示Activity的生命周期不同状态,用户交互事件,如点击,旋转等。

窗口4:显示应用的估算耗电量(要查看 CPU、网络和位置信息 (GPS) 资源,以及相关系统事件的具体耗电量情况,请将鼠标指针放在 Energy 时间轴中的条形上方):

CPU:cpu工作损耗电量

Network:网络通信损耗电量

Location:定位功能损耗电量

(5)随时查看电量损耗情况(在时间轴上拖动以选择要查看的区域):

0f1313c25d31

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());

}

}

小编的扩展链接

参考链接

会当凌绝顶,一览众山小

0f1313c25d31

举手之劳,赞有余香! ❤ 比心 ❤

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/4/42800.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息