我第一次触发多个警报有问题,下面是我的代码
这是启动程序活动,我在其中编写了以下代码:
**onCreate方法:
// Calling Method setNextAlarm two times..with different id and time
setNextAlarm(0,60000);
setNextAlarm(1,120000);setNextAlarm在这里::
private void setNextAlarm(int id,long time) {
AlarmManager mgr = (AlarmManager) TestAct.this
.getSystemService(Context.ALARM_SERVICE);
Intent i = new Intent(TestAct.this, OnBootReceiver.class);
i.putExtra("id", id);
Log.e("Firing up next alarm in "+id,""+time/(60*1000) +"minutes");
PendingIntent pi = PendingIntent.getBroadcast(TestAct.this, id, i,PendingIntent.FLAG_ONE_SHOT);
mgr.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, time, pi);
}当我运行这段代码时,它调用onBootReceiver,这是我们的广播接收器类。
所以我的问题是::
在此方法中定义了不同的时间和id之后
setNextAlarm(0,60000);
setNextAlarm(1,120000);,为什么它同时开火?除了第一次在固定的时间间隔内运行良好以外。
这是我的onBootReceiver类的onReceive方法
Bundle b = intent.getExtras();
int id = b.getInt("id");
if(id==1){
PERIOD=300000;
}else{
PERIOD=120000;
}
Log.e("OnBootReceiver"," Calling"+id+" in "+PERIOD/60000 + "minutes");
AlarmManager mgr=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
Intent i=new Intent(context, OnAlarmReceiver.class);
i.putExtra("id", id);
PendingIntent pi=PendingIntent.getBroadcast(context, id,i, 0);
mgr.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP,
SystemClock.elapsedRealtime()+60000,
PERIOD,
pi);谢谢。
发布于 2012-03-29 10:46:58
在OnBootReceiver中
mgr.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP,
SystemClock.elapsedRealtime() + 60000, PERIOD, pi);这是变化
我设置
SystemClock.elapsedRealtime() + 60000 for id = 0并设置
SystemClock.elapsedRealtime() + 120000 for id = 1问题解决了。
,但我仍在等待更好的解释。
我在这里几乎没有发现关于SystemClock.elapsedRealtime()的信息
自系统启动以来,elapsedRealtime()以毫秒为单位计算,包括深度睡眠。在测量可能跨越系统睡眠周期的时间间隔时,应使用此时钟。
http://developer.android.com/reference/android/os/SystemClock.html
https://stackoverflow.com/questions/9921189
复制相似问题