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

小酌鸡汤

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

为什么要优化应用消耗电池电量?

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

为什么要用 energy profiler?

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

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

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

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

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

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

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)来吧,一起预览一下吧:

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值