海外主机测评

您现在的位置是:首页 > 云服务器知识 > 正文

云服务器知识

alarmmanageralarmmanager 执行两次会不会产生两个闹钟

cds8202023-03-27云服务器知识112
本文目录一览:1、androidapp被杀死alarmmanager能不能唤醒2、AlarmManager能实现重复订一个闹钟,如果要重复订几个闹钟应该怎么办3、初探Alarm

本文目录一览:

  • 1、android app被杀死 alarmmanager能不能唤醒
  • 2、AlarmManager能实现重复订一个闹钟,如果要重复订几个闹钟应该怎么办
  • 3、初探AlarmManager:使用
  • 4、Android定时器AlarmManager
  • 5、android AlarmManager使用详解

android app被杀死 alarmmanager能不能唤醒

可以唤醒的,但是得需要注意设置进程属性。

在Android中,AlarmManager提供了不受休眠状态的系统定时功能,其一般使用方法如下。

1、创建一个BroadcastReceiver类的子类,接收定时器事件:

public class MyReceiver extends BroadcastReceiver {

......

}

2、在AndroidMenifest.xml中定义上述广播事件接收类的定义:

receiver android:name=".MyReceiver"

/receiver

3、在程序中在需要时设置定时器:

Intent intent = new Intent(context,MyReceiver.class);

PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);

AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);

alarmManager.set(AlarmManager.ELAPSED_REALTIME_WAKEUP , SystemClock.elapsedRealtime() + ms, pendingIntent);

经过ms毫秒之后,MyReceiver会被调用,从而实现定时触发。

AlarmManager能实现重复订一个闹钟,如果要重复订几个闹钟应该怎么办

AlarmManager只能设置一个定时闹钟和一个重复闹钟。后面设置的闹钟会覆盖前面的。

这种情况是需要你自己去计算的,也就是说,你需要计算你多个闹钟里哪个闹钟最近,然后设置到AlarmManager中。

处理的情况可能有点多:

1.如果用户新建或编辑了闹钟,要进行一次判断,判断哪个最近,再设置一次。

2.闹钟响过后,要马上重新算一次,再设置到AlarmManager。

3.用户关机的情况,很多手机是不支持关机闹钟的,考虑到这个要在手机开机的时候再去算一次。

4.两个闹钟如果时间一致,那么只可能响一个,尽可能避免设置重复闹钟。

初探AlarmManager:使用

AlarmManager是Android系统提供的一种执行定时任务的手段,一般适用于长时间或者需要唤醒cpu保证准时的定时任务,提供唤醒和非唤醒, 重复和一次性等模式。系统源码中的闹钟app就是基于它。设备关闭或是重启的时候会被清除。

PendingIntent的getXXX方法名根据targetClass的类型替换, targetClass是除了content provider的其他组件。

大致解释一下PendingIntent。它是对Intent的进一步封装,能够完成更多的操作。它通过一系列getXXX得到,其中有两个参数比较重要:requestCode和flag。

有时NotificatiON或AlarmManager会设置多个PendingIntent,PendingIntent通过requestCode区分不同,当通过它同时设置多个操作时需要注意设置不同的requestCode,否则后设置的会把先设置的覆盖掉。

FLAG_CANCEL_CURRENT :如果当前系统中已经存在一个相同的PendingIntent对象,那么就将先将已有的PendingIntent取消,然后重新生成一个PendingIntent对象。

FLAG_NO_CREATE :如果当前系统中不存在相同的PendingIntent对象,系统将不会创建该PendingIntent对象而是直接返回null。

FLAG_ONE_SHOT :该PendingIntent只作用一次。在该PendingIntent对象通过send()方法触发过后,PendingIntent将自动调用cancel()进行销毁,那么如果你再调用send()方法的话,系统将会返回一个SendIntentException。

FLAG_UPDATE_CURRENT :如果系统中有一个和你描述的PendingIntent对等的PendingInent,那么系统将使用该PendingIntent对象,但是会使用新的Intent来更新之前PendingIntent中的Intent对象数据,例如更新Intent中的Extras。

先解释一下type参数

不同闹钟类型对应的任务首次时间的获取方法:若为ELAPSED_REALTIME_WAKEUP,那么当前时间就为 SystemClock.elapsedRealtime();若为RTC_WAKEUP,那么当前时间就为System.currentTimeMillis()。

1.set

第二个方法是第一个方法的变体,区别就是从触发pendingintent变成了触发listener回调,但和pendingintent一样,只能和一个alarm绑定。后面的handler决定了在哪个handler中执行回调,填null则在主线程回调。

2.setExact

3.setWindow

4.setAndAllowWhileIdle

5.setAlarmClock

set方法提供设置一次性的闹钟,但随着Android系统的完善,考虑到功耗等等因素,需要更加精细地控制闹钟。因此提供了一些其他情况下的set方法。看下官方文档的描述:

在Android api19之前,set方法是精准的,但在19之后,为了降低频繁唤醒cpu造成的电量浪费,系统会自动将几个alarm放在一起触发,set方法自然也就无法保证准确性。

因此Android又提供了setExact和setWindow来保证准确性。setExact保证精准触发,setWindow保证在设置的时间段内一定触发。

然而在Android api23开始,Android加入了低电耗模式和应用待机模式。其中低电耗模式明确指出在该模式下setExact和setWindow都会延迟执行。但Android也给出了解决办法:

正如文档所述,setAndAllowWhileIdle和setExactAndAllowWhileIdle可以在低电耗下触发,或者使用setAlarmClock。

setAlarmClock和setAndAllowWhileIdle基本一致,都可以在低电耗模式下唤醒,持有mTriggerTime和mShowIntent(pendingIntent)两个成员变量,是对闹钟事件的一个封装,getNextAlarmClock返回的就是一个AlarmClockInfo。

1.setRepeating

2.setInExactRepeating

这两个方法可以重复执行设定的pendingIntent。区别同上。

7.1系统PendingIntent包装的Intent不能直接设置Parcable对象,但可以放到bundle中。经查阅好像是6.0以上会出现,需要注意。

Android定时器AlarmManager

AlarmManager是Android的全局定时器。就是在指定时间做一个事情(封装在PendingIntent)。通过PendingIntent的getActivity()、getService()或getBroadcast()来执行。

听起来AlarmManager和Timer很类似,但是Timer有可能因为手机休眠而被杀掉服务,但是AlarmManager可以做到唤醒手机。

注:ALARM_SERVIC是context的一个常量。

以上绝对时间就是手机的时间,相对时间是相对于当前开机时间来说。例如如果是绝对时间,那么你测试可以通过修改系统时间来提前触发。而相对时间的使用场景是强调多久之后触发,例如2小时后,这个时候把时间修改到2小时后也是没用的。

注:以前还有一个POWER_OFF_WAKEUP,即使在关机后还能提醒,但是Android4.0以后就没有了。

该方法用于设置一次性闹钟。第一个参数是闹钟类型,第二个参数是触发时间,第三个参数是动作。

和set一样,但是时间更精准。

重复闹钟,第1、2、4个参数同上,第3个参数是两次闹钟的时间间隔。

和setInexactRepeating一样,但是时间更精准。

以上四个方法时间精不精准的原因还没有深入研究,大概是是否允许系统同时发出多个提醒,意义在于系统唤醒cpu后会把时间接近的alarm同时发出,避免重复唤醒cpu,减少电量。

取消闹钟。

目的:在指定时间从一个发送个广播,收到广播后打印log。界面如下面这样。

布局:

广播接收器:

MainActivity

AndroidManifest要注册一下receiver

经过测试,以上的时间间隔intervalMillis即使设置5秒也是没用的,因为误差(几十秒呢)无法避免,即使是setRepeating。所以精确是相对的。

android AlarmManager使用详解

AlarmManager是android中系统自带的一个提醒服务,比如设置闹钟,做一个定时任务,还可以设置重复操作

AlarmManager中常用的有三个方法:

1、set(int type,long startTime,PendingIntent pi),用于设置一次闹钟。

2、setRepeating(int type,long startTime,long intervalTime,PendingIntent pi),用于设置重复闹钟。

3、setInexactRepeating(int type,long startTime,long intervalTime,PendingIntent pi),同样是用于设置重复闹钟,但是它是不准确的,相对于第二个方法,也更加节能。

下面就看看这些方法中的参数:

type为闹钟的类型,可分为四个常量:

ELAPSED_REALTIME:闹钟在睡眠状态下不可用,使用的是相对系统启动时间。

ELAPSED_REALTIME_WAKEUP:闹钟在睡眠状态下可用,使用的是相对系统启动时间。

RTC:闹钟在睡眠状态下不可用,使用的是真实时间。

RTC_WAKEUP:闹钟在睡眠状态下可用,使用的是真实时间。

startTime:为开始时间

intervalTime:为重复闹钟的间隔时间,内置了几种:

INTERVAL_FIFTEEN_MINUTES 15分钟

INTERVAL_HALF_HOUR 半个小时

INTERVAL_HOUR 一个小时

INTERVAL_HALF_DAY 半天

INTERVAL_DAY 一天

PendingIntent :广播的一个intent,我们用广播接受闹钟的定时任务,注册一个广播去接受,任务指令。

使用PendingIntent的getBroadcast (Context context, int requestCode, Intent intent, int flags)方法可以得到一个发送广播动作的PendingIntent对象

为以下4个常量或其他支持使用Intent.fillIn()来控制它的变量:

FLAG_CANCEL_CURRENT:如果描述的PendingIntent对象已经存在时,会先取消当前的PendingIntent对象再生成新的。

FLAG_NO_CREATE:如果描述的PendingIntent对象不存在,它会返回null而不是去创建它。

FLAG_ONE_SHOT:创建的PendingIntent对象只使用一次。

FLAG_UPDATE_CURRENT:如果描述的PendingIntent对象存在,则保留它,并将新的PendingIntent对象的数据替换进去。

另一个就是在manifest.xml中注册自己的广播

这样就可以实现定时任务了,如果要定时任务service启动还可以加上service

关于alarmmanager和alarmmanager 执行两次会不会产生两个闹钟的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

发表评论

评论列表

  • 这篇文章还没有收到评论,赶紧来抢沙发吧~