美文网首页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