我知道Java 8具有基于Joda Time的改进的日期和时间库,但是我对旧库中的决策感到非常好奇。我没有找到有关java.util.Date构造函数弃用基本原理的任何很好的解释(我发现的最接近的问题是:Difference between new Date() and Calendar date,但它没有询问过时的方法/构造函数,并且没有可接受的答案)。
构造函数java.util.Date(年,月,日)被认为已弃用,我们应该使用新的GregorianCalendar(年+ 1900,月,日)。如果我们在Calendar实例上调用getTime()(返回Date ...),除了避免使用不推荐使用的构造方法外,我们获得了什么?甚至java.sql.Date.toLocalDate在内部也使用了一些不赞成使用的方法。
我的代码库中充斥着这种模式(新的GregorianCalendar后跟getTime)只是为了避免过时的java.util.Date方法(我需要JPA和JDBC中的java.util.Date和java.sql.Date),但我不确定当时的意义是什么(*)。
(*)如今,我终于可以将它们全部更改为LocalDate了,因为无论如何,这就是我真正需要的-保存用户键入的内容而无需任何时区转换。
答案 0 :(得分:3)
请参见java.util.Date
的javadoc中的第二段:
在JDK 1.1之前,类
Date
具有两个附加功能。它允许将日期解释为年,月,日,小时,分钟和秒值。它还允许格式化和解析日期字符串。不幸的是,这些功能的API 不适合国际化。从JDK 1.1开始,应使用Calendar
类在日期和时间字段之间进行转换,而应使用DateFormat
类来格式化和解析日期字符串。Date
中的相应方法已弃用。
因此,要回答您的问题“我们获得了什么?”,答案是“支持国际化”:
能够指定时区(使用Calendar
)。
使用非格里高里历的能力(使用Calendar
)。
能够使用日期字符串的本地化格式和解析(使用DateFormat
)。
答案 1 :(得分:1)
旧图书馆允许传入年,月,日等物品,从而根据阳历中的条目构造java.util.Date
物品。
由于许多原因,这是有问题的。首先,公历系统是从儒略历系统过渡而来的混合日历系统。这种过渡包括需要“跳过”日期以使儒略历系统与季节重新对齐。因此,还有很多日子。令人惊讶的是,java.util.Date
在捕获此行为方面做得不错,
java.util.Date
对象的格里高利日历的牢固绑定意味着实现其他日历系统是有问题的,因为您需要在格里高利系统之上实现它们。新的日历系统尝试通过以下方式避免这种情况:
展望未来,人们仅应将java.util.Date
用作时间戳的薄包装,而更多的是与旧API兼容。所有Date操作都应在适当的Calendar实例中完成。