Я получаю миллисекунды для диспетчера тревог, чтобы установить повторяющуюся тревогу, и я получаю странные результаты -
Я установил тревогу в 8:55
LocalDateTime Earliest Day : 2018-05-22T08:55
Instant : 2018-05-22T08:55:00Z
Затем я использовалэтот метод для получения миллисекунд с начала эпохи (1970 г.) -
LogUtils.LOGD(TAG, instant.toEpochMilli() + " : instant.toEpochMilli()");
Я получил сигнал тревоги сразу, поэтому я проверил старый способ получения миллисекунд из Календаря против времени Java -
1526996659862 : System.currentTimeMillis() :
1526979300000 : instant.toEpochMilli()
1526997319862 : calendar.getTimeInMillis()
Я получил локальное время, построенное на этом -
LocalDateTime earliestDay = LocalDateTime.of(
now.getYear(), now.getMonth().getValue(), now.getDayOfMonth(),
localTime.getHour(), localTime.getMinute(), localTime.getSecond());
Затем я получаю его для преобразования в Мгновенное и использует ZoneOffset - UTC -
Instant instant = earliestDay.toInstant(ZoneOffset.UTC);
Я не уверен, почему toEpochMilliseconds isnне работает, как задумано?
Календарь ввода -
Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(System.currentTimeMillis());
calendar.set(Calendar.HOUR_OF_DAY, earliestDay.getHour());
calendar.set(Calendar.MINUTE, earliestDay.getMinute());