自 Java 9 以来,Java 日期和时间 API 发生了变化。LocalDateTime 现在具有微秒精度。
Java 9 有一个全新的 java.time.Clock 实现,能够以比毫秒(小数点的三位数字)更精细的分辨率捕获当前时刻。
我们从后端服务获取时间(以微秒为单位)。
System.currentTimeMillis > 1565245051795 > 2019-08-08T06:17:31.795
Service.getTime > 1565245051795306 > 2019-08-08T06:17:31.795306
为了构造一个在我们的应用程序中使用的 LocalDateTime,我们做
long timeMicros = service.getTime();
long timeMillis = timeMicros / 1000;
LocalDateTime ldt = Instant.ofEpochMilli(timeMillis).atZone(ZoneId.systemDefault()).toLocalDateTime();
为了查询服务,我们再次需要时间微秒,然后我们做
long timeMillis = dateTime.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
long timeMicros = timeMillis * 1000;
问题是我们无法恢复时间微秒精度。
是否可以创建具有微秒精度的 Instant?
我们现在使用的是 Java 11。当我们的一个 JUnit 测试由于微秒精度的提高而失败时,我注意到了这一变化。
对于 JUnit 测试,我找到了一种解决方法:
private static final LocalDateTime START = LocalDateTime.now().truncatedTo(ChronoUnit.MILLIS);
我不确定这是一种解决方法还是一个实际的解决方案,但从时间戳添加最后三微秒数字似乎有效。
long micros = 306L; //TODO get the last three digits from the timeMicros
ldt.plus(micros, ChronoUnit.MICROS));