我想知道是否有一种方法可以使用Java 8的新的LocalDate, LocalTime或LocalDateTime类来获取自1-1-1970 (epoch)以来的当前毫秒。
已知的方法如下:
long currentMilliseconds = new Date().getTime();
or
long currentMilliseconds = System.currentTimeMillis();
我想知道是否有一种方法可以使用Java 8的新的LocalDate, LocalTime或LocalDateTime类来获取自1-1-1970 (epoch)以来的当前毫秒。
已知的方法如下:
long currentMilliseconds = new Date().getTime();
or
long currentMilliseconds = System.currentTimeMillis();
当前回答
我在不指定时区的情况下,
System.out.println("ldt " + LocalDateTime.now().atZone(ZoneId.systemDefault()).toInstant().toEpochMilli());
System.out.println("ctm " + System.currentTimeMillis());
给了
ldt 1424812121078
ctm 1424812121281
正如你所看到的,数字是相同的,除了一个小的执行时间。
以防你不喜欢系统。currentTimeMillis,使用Instant.now().toEpochMilli()
其他回答
从Java 8开始,你可以调用Java .time. instant . toepochmilli()。
例如,调用
final long currentTimeJava8 = Instant.now().toEpochMilli();
得到的结果和
final long currentTimeJava1 = System.currentTimeMillis();
如果你有一个Java 8 Clock,那么你可以使用Clock .millis()(尽管它建议你使用Clock . Instant()来获得一个Java 8 Instant,因为它更准确)。
为什么要使用Java 8时钟?所以在你的DI框架中,你可以创建一个时钟bean:
@Bean
public Clock getClock() {
return Clock.systemUTC();
}
然后在你的测试中,你可以很容易地模拟它:
@MockBean private Clock clock;
或者你可以有一个不同的bean:
@Bean
public Clock getClock() {
return Clock.fixed(instant, zone);
}
这有助于不可测量地断言日期和时间的测试。
你可以试试这个:
long diff = LocalDateTime.now().atZone(ZoneOffset.UTC).toInstant().toEpochMilli();
我认为这个更简单:
ZonedDateTime zdt = ZonedDateTime.of(LocalDateTime.now(), ZoneId.systemDefault());
Assert.assertEquals(System.currentTimeMillis(), zdt.toInstant().toEpochMilli());
获取类似System.currentTimeMillis()(从UTC)的millis。
要获得以毫秒为单位的当前时间(从epoch开始),请使用System.currentTimeMillis()。