1

我的应用程序为特定时间安排了多个警报。这些警报是在应用程序启动时安排的。(每天有 5 个警报,导致每周 35 个警报)...

我已经通过日志验证了这些警报是在应用程序启动时安排的。

问题是当我开始测试我的应用程序时,7 个警报完全正常。然而,第 8 个警报没有响起。我已经通过让我的设备静止超过 1 天来测试这种情况。如何调试此行为以及阻止触发警报的可能原因是什么。

编辑:

调度代码:

try {
    if (info != null) {
        Calendar c = Calendar.getInstance();
        c.set(Calendar.YEAR, year);
        c.set(Calendar.MONTH, month);
        c.set(Calendar.DAY_OF_MONTH, day);
        c.set(Calendar.HOUR_OF_DAY, info.getHour());
        c.set(Calendar.MINUTE, info.getMinute());
        c.set(Calendar.SECOND, 0);

        Intent intent = new Intent(context, AlarmReceiverActivity.class);
        intent.putExtra("name", info.getPrayerName());
        intent.putExtra("sound", soundType);

        intent.putExtra("time", formatTimeClock(context, info.getHour(), info.getMinute()));

        PendingIntent pendingIntent = PendingIntent.getActivity(context, alarmId, intent, PendingIntent.FLAG_CANCEL_CURRENT);

        AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        am.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), pendingIntent);
    }
} catch (Exception e) {
    Log.e("ALarmSchedularManager", e.getMessage());
}
4

2 回答 2

2

如何调试此行为

用于adb shell dumpsys alarm查看您的预定警报是什么以及下次调用它们的时间。

阻止触发警报的可能原因有哪些

您的代码似乎没有考虑到时间已经过去的可能性,尽管这可能在您上面显示的代码片段之外处理。

于 2013-02-19T12:28:45.073 回答
1

希望下面的代码会有所帮助,我在我的应用程序中使用了相同的代码。这里在 AlarmManager 类中传递的用于重复的参数应该是 24*60*60*1000

AlarmManager am = (AlarmManager) ct.getSystemService(Context.ALARM_SERVICE);         
Intent intent1 = new Intent(ct, TimeAlarm.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(ct, 0,intent1, PendingIntent.FLAG_CANCEL_CURRENT);

Date curr=new Date();
curr.setHours(h);
curr.setMinutes(m);
c.setTime(curr);
c.set(Calendar.SECOND, 0);

Calendar c1 = Calendar.getInstance();
am.setRepeating(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(),24*60*60*1000, pendingIntent);

您可以使用 AlarmManager.INTERVAL_DAY 而不是硬代码操作 (24*60*60*1000)。检查这个不同的时间间隔长达 1 天http://developer.android.com/reference/android/app/AlarmManager.html#INTERVAL_DAY

于 2013-02-19T10:38:04.673 回答