Java 日期 API:设计缺陷的遗留问题
Java 日期 API,包含 java.util.Date 和 java.util.Calendar 类,长期以来一直存在因其复杂且有问题的设计而受到批评。由于几个明显的缺陷,这些类被称为“可怕的混乱”:
-
日期的可变性: Date 类是可变的,允许直接修改其内部状态。这破坏了对象不变性,这是现代软件开发的一个关键原则。
-
时间的错误表示:日期表示时间戳,仅捕获精确的时刻,而不是日期。这种时间和日期概念的合并带来了不必要的复杂性,并可能阻碍日期操作。
-
转换不便:没有直接的方法在日期组件(例如日、月、年)之间进行转换和一个 Date 对象。
-
日历的笨拙用法:日历是一个复杂的类,试图统一不同的日历系统合并为一个实体。它的界面很繁琐,很难有效使用。
混乱的起源:
这些有缺陷的类是如何进入 Java SDK 的?虽然有些问题回想起来可能很明显,但它们最初的包含可能受到以下几个因素的影响:
-
时间压力:最初的 API 是在 Java 早期开发的,当时速度和效率至关重要。可变的 Date 类当时可能被视为一种性能优化。
-
设计疏忽: Date 中时间和日期的合并以及在 Calendar 中概括日历系统的尝试可能会源于最初的设计规范缺乏明确性。
-
历史限制:Java 一直不情愿对其核心 API 进行重大更改,延续日期和日历中的设计缺陷以保持向后兼容性。
以上是为什么 Java 的 Date API 被认为是设计灾难?的详细内容。更多信息请关注PHP中文网其他相关文章!