我得到了警报管理器设置重复警报的毫秒数,我得到了奇怪的结果-
我定了早上 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 -
LocalDateTime earliestDay = LocalDateTime.of(
now.getYear(), now.getMonth().getValue(), now.getDayOfMonth(),
localTime.getHour(), localTime.getMinute(), localTime.getSecond());
然后我将其转换为 Instant 并使用 ZoneOffset - UTC -
Instant instant = earliestDay.toInstant(ZoneOffset.UTC);
我不确定为什么 toEpochMilliseconds 没有按预期工作?
日历输入 -
Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(System.currentTimeMillis());
calendar.set(Calendar.HOUR_OF_DAY, earliestDay.getHour());
calendar.set(Calendar.MINUTE, earliestDay.getMinute());