美文网首页Android 性能优化
(四)Android 性能优化 Energy Profiler

(四)Android 性能优化 Energy Profiler

作者: 科技猿人 | 来源:发表于2020-07-01 00:09 被阅读0次

小酌鸡汤

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

本文来源《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());
    }
}

小编的扩展链接

参考链接

会当凌绝顶,一览众山小

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

相关文章

网友评论

    本文标题:(四)Android 性能优化 Energy Profiler

    本文链接:https://www.haomeiwen.com/subject/tdffqktx.html