使用Android通知时出现奇怪错误

使用Android通知时出现奇怪错误,android,notifications,broadcastreceiver,Android,Notifications,Broadcastreceiver,Helo,我有一个android应用程序,提醒用户每天在特定的时间服药。因此,我使用通知和广播接收器。当我现在将通知设置为在特定时间(例如6小时后)出现时,我只会在该特定时间出现“[App]has stopped”(应用程序已停止)对话框。但当我进入调试模式并将通知设置为在大约1分钟内出现时,它将通过所有方法,不会出现任何错误,我会收到通知。我的课程如下 public class AlarmReceiver extends BroadcastReceiver { String notifica

Helo,我有一个android应用程序,提醒用户每天在特定的时间服药。因此,我使用通知和广播接收器。当我现在将通知设置为在特定时间(例如6小时后)出现时,我只会在该特定时间出现“[App]has stopped”(应用程序已停止)对话框。但当我进入调试模式并将通知设置为在大约1分钟内出现时,它将通过所有方法,不会出现任何错误,我会收到通知。我的课程如下

public class AlarmReceiver extends BroadcastReceiver {

String notificationTitle;
String notificationText;

@Override
public void onReceive(Context context, Intent intent) {
        //Monday = 1, Tuesday = 2, etc.
        int actualDay = new DateTime().getDayOfWeek();
        if (getTypeOfNotification() == NotificationType.TYPE_DOSE) {
            notificationTitle = context.getString(R.string.notificationPills);
            notificationText = context.getString(R.string.notificationDose1)+ " " + DataStorage.getInstance().getSelectedWeeklyDose()[actualDay - 1] + " " + context.getString(R.string.notificationDose2);
        }
        else {
            notificationTitle = context.getString(R.string.notificationMeasurement);
            notificationText = context.getString(R.string.notificationMeasurementText);
        }
        showNotification(context);
}

public void setRecurringAlarm(Context context) {
    Calendar updateTime = Calendar.getInstance();
        updateTime.set(Calendar.HOUR_OF_DAY, DataStorage.getInstance().getSelectedNotificationTime().getHourOfDay());
        updateTime.set(Calendar.MINUTE, DataStorage.getInstance().getSelectedNotificationTime().getMinuteOfHour());
        updateTime.set(Calendar.SECOND, 0);
        //check if that time is already reached and if yes, start a new alarm tomorrow
        Calendar rightNow = Calendar.getInstance();
        if (rightNow.after(updateTime)) {
            updateTime.add(Calendar.DAY_OF_MONTH, 1);
        }
        setAlarm(AlarmManager.INTERVAL_DAY, updateTime, context);
}

private void setAlarm(long interval, Calendar updateTime, Context context) {
    Intent notificator = new Intent(context, AlarmReceiver.class);
    PendingIntent recurringNotification = PendingIntent.getBroadcast(context,
            0, notificator, 0);
    AlarmManager alarms = (AlarmManager) context.getSystemService(
            Context.ALARM_SERVICE);
    alarms.cancel(recurringNotification);
    alarms.setInexactRepeating(AlarmManager.RTC_WAKEUP,
            updateTime.getTimeInMillis(), interval, recurringNotification);
}

public void cancelAlarm(Context context) {
    Intent notificator = new Intent(context, AlarmReceiver.class);
    AlarmManager alarms = (AlarmManager) context.getSystemService(
            Context.ALARM_SERVICE);
    PendingIntent cancelNotification = PendingIntent.getBroadcast(context,
            0, notificator, PendingIntent.FLAG_CANCEL_CURRENT);
    alarms.cancel(cancelNotification);  
}

private void showNotification(Context context){
    NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
    Intent myIntent = new Intent(Intent.ACTION_VIEW);
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0,
            myIntent, Intent.FLAG_ACTIVITY_NEW_TASK);
    Notification noti = new NotificationCompat.Builder(context)
            .setContentTitle(notificationTitle)
            .setContentText(notificationText)
            .setSmallIcon(R.drawable.pills)
            .setContentIntent(pendingIntent).build();
    noti.defaults |= Notification.DEFAULT_SOUND;
    noti.flags |= Notification.FLAG_AUTO_CANCEL;
    notificationManager.notify(0, noti);
}

private NotificationType getTypeOfNotification() {
    DateTime latestMeasurement = DataStorage.getInstance().getLatestMeasurementDate();
    //First check special case if there is no latest measurement. Then set actual date.
    if (latestMeasurement != null) {
        Calendar today = Calendar.getInstance();
        if (today.get(Calendar.DAY_OF_YEAR) - latestMeasurement.getDayOfYear() == DataStorage.getInstance().getSelectedMeasureInterval()) {
            return NotificationType.TYPE_MEASUREMENT;
        }
        else return NotificationType.TYPE_DOSE;
    }
    else {
        return NotificationType.TYPE_DOSE;
    }
}
}

警报设置方式如下(在另一个活动中):


有人能帮我吗?

在你的帮助下我找到了它。不知道您可以在控制台上发出logcat错误。错误是接收通知时发生的错误数据库查找


谢谢

发布您的logcat错误。
adb logcat
将手机插入计算机。
AlarmReceiver receiver = new AlarmReceiver();
receiver.cancelAlarm(NotificationActivity.this);
receiver.setRecurringAlarm(NotificationActivity.this);