WakeLock:官方给出来的定义是WakeLock是一种机制,用于指示应用程序需要设备继续工作。也就是说WakeLock可以确保应用程序一直运行保持cpu一直在工作。
任何需要使用WakeLock的应用程序都需要添加权限
//获取WAKE_LOCK 权限
<uses-permission android:name="android.permission.WAKE_LOCK" />
使用acquire()方法获取唤醒锁,使用release()方法释放唤醒锁,值得注意一个获取对应一个释放所以获取和释放需要成对出现。以下为实例代码:
//不推荐使用,在耗电一块不太出色
//如果需要屏幕常亮可以在theme中配置 <item name="android:keepScreenOn">true</item>
//也可以代码中使用 getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
//但是要知道有这么一个东西可以使用来保持cpu一直运行阻止cpu睡眠,因此使用WakeLock会导致耗电量增加
//这里如果非及时性的任务可以使用闹钟AlarmManager处理
PowerManager.WakeLock wakeLock;
/**
* 通过wakeLock保证cpu补睡眠一直运行
*/
@SuppressLint("InvalidWakeLockTag")
private void lockKeep() {
//获取PowerManager对象
PowerManager pm = (PowerManager) getSystemService(POWER_SERVICE);
//判断是否支持wakeLock PARTIAL_WAKE_LOCK级别
pm.isWakeLockLevelSupported(PowerManager.PARTIAL_WAKE_LOCK);
//通过PowerManager对象获取wakeLock 这里PARTIAL_WAKE_LOCK是只确保cpu运行
wakeLock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "my_lock");
//拿到wakelock 保证cpu不睡眠休息
//这里记住wakeLock 获取与释放是需要成对出现的 所以要在销毁时释放wakeLock
wakeLock.acquire();
}
AlarmManager:官方给出来的定义是WakeLock提供对系统警报服务的访问。可以让应用程序在未来的某个时间点运行。当闹钟响起时也就是,Intent为其注册的信息由系统广播,如果目标应用程序尚未运行,则自动启动目标应用程序。当设备处于休眠状态时,注册的警报被保留(如果设备在此期间关闭,也可以选择性地唤醒设备),但是如果设备被关闭并重新启动,则将被清除。也就是说可以通过AlarmManager去每隔一段时间就去唤醒一次cpu。
首先创建等待意图(PendingIntent )然后添加拦截器注册一个广播,去拦截系统广播的通知,然后使用AlarmManager的setRepeating来循环的广播然后拦截做相应处理。
//闹钟管理者
AlarmManager alarmManager;
AlarmReceiver alarmReceiver = new AlarmReceiver();
/**
* 闹钟形式的
*/
private void alarmKeep() {
alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
Intent alarmIntent = new Intent();
alarmIntent.setAction("my_location");
//创建一个等待意图 getBroadcast方法时检索意图(intent),然后去执行一个广播
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, alarmIntent, 0);
//创建一个拦截器拦截意图my_location
IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction("my_location");
//注册一个广播去拦截意图
registerReceiver(alarmReceiver, intentFilter);
//设置重复 这里就是设置5秒闹钟他会唤醒一次
alarmManager.setRepeating(AlarmManager.ELAPSED_REALTIME, SystemClock.elapsedRealtime(), 5000,
pendingIntent
);
}
public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (TextUtils.equals(intent.getAction(), "my_location")) {
//做一些事情...
}
}
}
当时非及时性的任务就可以通过AlarmManager来替代WakeLock去唤醒cpu执行任务,这样就可以每隔一段时间去唤醒一次不需要一直保持cpu的运行,这样就可以减小APP的耗电量。
网友评论