AlarmManager定时器发送一个延时广播

AlarmUtil.java

public static final String ACTION_TIME_OVER = "com.spt.carengine.time.over";

    public static void startTimer(Context context, String action, long time) {
        Intent intent = new Intent(action);
        PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent,
                0);
        AlarmManager alarm = (AlarmManager) context
                .getSystemService(Context.ALARM_SERVICE);
        alarm.setExact(AlarmManager.RTC_WAKEUP, time, sender);
    }
    
    public static void cancelTimer(Context context, String action) {
        Intent intent = new Intent(action);
        PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent,
                0);

        AlarmManager alarm = (AlarmManager) context
                .getSystemService(context.ALARM_SERVICE);
        alarm.cancel(sender);
    }

调用的地方 注意了一定要用当前系统时间 加上等待的时间
    long current = System.currentTimeMillis();
                long value = current + 60000; // 24 * 60 * 60 *1000
                AlarmUtil.startTimer(MainActivity.this,
                        AlarmUtil.ACTION_TIME_OVER, value);// 24 * 60 * 60 *1000
调用方法跟普通广播差不多 先注册再在onreceive中实现
注册:
 registerNaviBroadcast(MainActivity.this,
                        AlarmUtil.ACTION_TIME_OVER);
private void registerNaviBroadcast(Context context, String action) {
        IntentFilter filter = new IntentFilter();
        filter.addAction(action);
        context.registerReceiver(mReceiver, filter);
    }
广播接收实现
 private BroadcastReceiver mReceiver = new BroadcastReceiver() {

        @Override
        public void onReceive(Context context, Intent intent) {
            if (intent == null) {
                return;
            }
            String action = intent.getAction();
            Log.d("MapFactoryTest", "onReceive action: "+action);
            switch (action) {
                case AlarmUtil.ACTION_TIME_OVER:
                 //..............
                    break;
            }
        }
    };



安卓的BroadcastReceiver可以被用来接收系统发送广播消息,而AlarmManager则可以用来触发在特定时间触发的定时任务。然而,在某些情况下,我们可能会遇到AlarmManager无法将广播发送给BroadcastReceiver的问题。 出现这种情况的原因可能有多个。一种可能性是未正确注册BroadcastReceiver。在AndroidManifest.xml文件中,需要添加正确的intent-filter来指定BroadcastReceiver接收的广播类型。如果没有正确添加intent-filter,那么AlarmManager发送广播就无法被BroadcastReceiver接收到。 另一种可能性是未正确设置AlarmManagerPendingIntent。在设置AlarmManager时,我们需要为PendingIntent指定BroadcastReceiver的类。如果未正确设置PendingIntent,那么AlarmManager发送广播就无法正确地被指定的BroadcastReceiver接收到。 此外,还有可能是由于权限问题导致BroadcastReceiver无法接收AlarmManager发送广播。当AlarmManager发送广播时,需要确保应用程序具有相应的权限。如果没有正确配置权限,那么BroadcastReceiver将无法接收到AlarmManager发送广播。 解决这个问题的步骤包括: 1. 在AndroidManifest.xml文件中确保正确注册BroadcastReceiver,并添加正确的intent-filter。 2. 在设置AlarmManager时,确保为PendingIntent正确指定BroadcastReceiver的类。 3. 确认应用程序具有相应的权限来接收AlarmManager发送广播。 通过以上步骤的检查和调整,应该能够解决Android的BroadcastReceiver收不到AlarmManager发送广播的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值