繁体   English   中英

我应该使用java.util.Date还是切换到java.time.LocalDate

[英]Should I use java.util.Date or switch to java.time.LocalDate

编辑:嗯,显然这是基于意见的,所以让我试着更准确地改写它 -

在不需要任何向后兼容性的Java代码中使用LocalDate,LocalTime等有任何明确的警告或缺点,如果是这样 - 它们是什么?

我正在寻找像“当前EE库X和Y无法正确使用LocalDate”或“这个非常有用的模式被LocalTime打破”等等。


(这是原始问题供参考)

在Java 8中,引入了新的时间API,即java.time.LocalDate等,但java.util.Date未标记为已弃用。

我正在编写一个新项目,它不需要向后兼容。 我应该只使用LocalDate,LocalDateTime等吗? 使用这个新API是否有任何缺点,而不是旧的java.util.Date?

特别是 - 我将主要使用JDBC。 从我所看到的JDBC很好地处理java.util.Date。 它是否适合LocalDate?

搜索产生了许多网站,告诉他们如何从一种格式转换为另一种格式,但是如果新代码使用旧的API,则没有明确的答案。

谢谢。

尽管名称,java.util.Date可用于存储日期和时间(它存储自纪元以来的UTC毫秒偏移量)

我肯定会使用新的API,因为它具有更强大的功能:

  • 更容易格式化/解析。 API有自己的格式/解析方法
  • API包括加法/减法操作(minusMinutes,plusDays等)

以上都不适用于java.util.Date

Old Date也可以像这样转换为LocalDateTime:

Date oldDate = ...
LocalDateTime newDateTime = 
  LocalDateTime.from(Instant.ofEpochMilli(oldDate.getTime()));

我正在添加Ole VV正确答案

JDBC 4.2

特别是 - 我将主要使用JDBC。

JDBC 4.2增加了对与数据库交换java.time对象的支持。 请参阅PreparedStatement::setObjectResultSet::getObject方法。

ZoneId z = ZoneId.of( "Africa/Tunis" ) ;
LocalDate today = LocalDate.now( z ) ;
myPreparedStatement.setObject( … , today ) ;

恢复。

LocalDate ld = myResultSet.getObject( … , LocalDate.class ) ;

对于逃避我的原因,JDBC规范并不要求两个最常用的类支持: InstantZonedDateTime 您的数据库和JDBC驱动程序可能会也可能不会添加对这些的支持。

如果没有,您可以轻松转换。 OffsetDateTime开始,需要JDBC支持。

OffsetDateTime odt = myResultSet.getObject( … , OffsetDateTime.class ) ;

要通过特定区域(时区)的人使用的挂钟时间来查看此时刻,请应用ZoneId以获取ZonedDateTime对象。

ZoneId z = ZoneId.of( "Asia/Kolkata" ) ;
ZonedDateTime zdt = odt.atZoneSameInstant() ;

要调整为UTC,请提取Instant 根据定义, Instant始终为UTC。

Instant instant = odt.toInstant() ;

您可以转换另一种方式,写入数据库。

myPreparedStatement.setObject( … , zdt.toOffsetDateTime() ;  // Converting from `ZonedDateTime` to `OffsetDateTime`. Same moment, same point on the timeline, different wall-clock time.

…和:

myPreparedStatement.setObject( … , instant.atOffset( ZoneOffset.UTC ) ) ;  // Converting from `Instant` to `OffsetDateTime`. Same moment, same point on the timeline, and even the same offset. `OffsetDateTime` is a more flexible class with abilities such as (a) applying various offsets and (b) flexible formatting when generating text, while `Instant` is meant to be a more basic building-block class. 

请注意java.time中使用命名约定atfromtowith等。

Java(现代和旧版)和标准SQL中的日期时间类型表。


关于java.time

java.time框架内置于Java 8及更高版本中。 这些类取代了麻烦的旧遗留日期时间类,如java.util.DateCalendarSimpleDateFormat

要了解更多信息,请参阅Oracle教程 并搜索Stack Overflow以获取许多示例和解释。 规范是JSR 310

现在处于维护模式Joda-Time项目建议迁移到java.time类。

您可以直接与数据库交换java.time对象。 使用符合JDBC 4.2或更高版本的JDBC驱动程序 不需要字符串,不需要java.sql.*类。

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展了java.time。 该项目是未来可能添加到java.time的试验场。 您可以在这里找到一些有用的类,比如IntervalYearWeekYearQuarter ,和更多

Java 8及更高版本:无后顾之忧

不,如果您使用的是Java 8或更高版本(内置它),那么您就不应该使用java.time这个现代Java日期和时间API。

人们可能会简单地考虑的唯一问题是你已经排除的那个。

我正在编写一个新项目,它不需要向后兼容。

即使为了向后兼容,您也可以安全地使用java.time,因为转换方法是从Java 8构建到旧类中的。

Java 6和7:权衡

如果您使用的是Java 6或7,则需要使用适用于java.time的ThreeTen- Backport,进一步适用于ThreeTenABP中API级别26以下的Android。 如果您只做很少非常简单的日期和时间工作,并且前向兼容性不是一个问题,您可以考虑外部依赖是否值得。 请注意,您的外部依赖项只是Java 8及更高版本中内置的后端,因此非常坚固,因此在迁移到Java 8或更高版本之前,您只需要它。 此时您可以更改导入,重新测试并取消后退。

你可以想象的负债的例子

当前EE库X和Y无法与LocalDate一起正常工作

这里有一些例子,JDK中的库类也是如此。 我的选择是在我自己的代码中使用java.time,只在调用之前转换为尚未接受java.time类型的API。 相反,如果我从API获得一个过时类的实例,首先将其转换为其余部分并使用java.time。

使用LocalTime打破了这个非常有用的模式

我知道没有这种模式。 相反,java.time使用模式不可变对象工厂方法 ,与大多数旧类相反。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM