Java 8 中的 LocalDate 和 LocalTime 的神奇之处

Java 8新增了LocalDateLocalTime接口,为什么要搞一套全新的处理日期和时间的API?因为旧的java.util.Date实在是太难用了。

java.util.Date月份从0开始,一月是0,十二月是11,变态吧!java.time.LocalDate月份和星期都改成了enum,就不可能再用错了。

java.util.DateSimpleDateFormatter都不是线程安全的,而LocalDateLocalTime和最基本的String一样,是不变类型,不但线程安全,而且不能修改。

java.util.Date是一个“万能接口”,它包含日期、时间,还有毫秒数,如果你只想用java.util.Date存储日期,或者只存储时间,那么,只有你知道哪些部分的数据是有用的,哪些部分的数据是不能用的。在新的Java 8中,日期和时间被明确划分为LocalDateLocalTimeLocalDate无法包含时间,LocalTime无法包含日期。当然,LocalDateTime才能同时包含日期和时间。

新接口更好用的原因是考虑到了日期时间的操作,经常发生往前推或往后推几天的情况。用java.util.Date配合Calendar要写好多代码,而且一般的开发人员还不一定能写对。

LocalDate

看看新的LocalDate怎么用:

// 取当前日期:
LocalDate today = LocalDate.now(); // -> 2014-12-24
// 根据年月日取日期,12月就是12:
LocalDate crischristmas = LocalDate.of(2014, 12, 25); // -> 2014-12-25
// 根据字符串取:
LocalDate endOfFeb = LocalDate.parse("2014-02-28"); // 严格按照ISO yyyy-MM-dd验证,02写成2都不行,当然也有一个重载方法允许自己定义格式
LocalDate.parse("2014-02-29"); // 无效日期无法通过:DateTimeParseException: Invalid date

日期转换经常遇到,比如:

// 取本月第1天:
LocalDate firstDayOfThisMonth = today.with(TemporalAdjusters.firstDayOfMonth()); // 2014-12-01
// 取本月第2天:
LocalDate secondDayOfThisMonth = today.withDayOfMonth(2); // 2014-12-02
// 取本月最后一天,再也不用计算是28,29,30还是31:
LocalDate lastDayOfThisMonth = today.with(TemporalAdjusters.lastDayOfMonth()); // 2014-12-31
// 取下一天:
LocalDate firstDayOf2015 = lastDayOfThisMonth.plusDays(1); // 变成了2015-01-01
// 取2015年1月第一个周一,这个计算用Calendar要死掉很多脑细胞:
LocalDate firstMondayOf2015 = LocalDate.parse("2015-01-01").with(TemporalAdjusters.firstInMonth(DayOfWeek.MONDAY)); // 2015-01-05

LocalTime

LocalTime只包含时间,以前用java.util.Date怎么才能只表示时间呢?答案是,假装忽略日期。

LocalTime包含毫秒:

LocalTime now = LocalTime.now(); // 11:09:09.240

你可能想清除毫秒数:

LocalTime now = LocalTime.now().withNano(0)); // 11:09:09

构造时间也很简单:

LocalTime zero = LocalTime.of(0, 0, 0); // 00:00:00
LocalTime mid = LocalTime.parse("12:00:00"); // 12:00:00

时间也是按照ISO格式识别,但可以识别以下3种格式:

  • 12:00
  • 12:01:02
  • 12:01:02.345

JDBC

最新JDBC映射将把数据库的日期类型和Java 8的新类型关联起来:

SQL -> Java
--------------------------
date -> LocalDate
time -> LocalTime
timestamp -> LocalDateTime

再也不会出现映射到java.util.Date其中日期或时间某些部分为0的情况了。

最后总结一下,怎么才能愉快地处理日期和时间?答案是:立刻升级到Java 8!

Java 8引入了`java.time`包,提供了`LocalDate`、`LocalTime`和`LocalDateTime`三个新的时间类,分别用来表示无时区信息的日期、时间以及日期和时间的组合。它们都是不可变类,保证了线程安全,适合用于多线程环境。`LocalDate`用于仅包含年月日的场景,如生日或纪念日;`LocalTime`用于表示一天的具体时间点,例如工作开始或结束的时间;而`LocalDateTime`则适合需要同时处理日期和时间的场景,如日程安排或事件记录。 参考资源链接:[Java8时间API实战:LocalDateLocalDateTime解析](https://wenku.csdn.net/doc/5gup5xforu?spm=1055.2569.3001.10343) 当需要操作这些类时,可以通过它们各自的静态工厂方法来创建实例,如`of`和`now`。例如,获取当前的日期和时间可以通过`LocalDateTime.now()`实现。如果需要对日期和时间进行计算,可以使用`plus`、`minus`和`until`等方法,它们提供了一种不可变的方式来生成新的日期时间实例。例如,计算两个日期之间的天数差异可以使用`ChronoUnit.DAYS.between(LocalDate startDate, LocalDate endDate)`方法。 在选择使用哪个类时,需要根据实际需求来决定。如果仅需要日期,则选择`LocalDate`;如果仅需要时间,则选择`LocalTime`;如果需要同时处理日期和时间,则选择`LocalDateTime`。由于它们都是不可变的,所以在多线程环境下使用它们时无需担心线程安全问题。此外,这些时间类还支持与旧版`java.util.Date`和`Calendar`类进行互操作,允许在新旧API之间平滑过渡。 对于需要考虑时区的场景,可以使用`ZonedDateTime`,它是`LocalDateTime`加上时区信息的扩展。如果需要进行复杂的日期时间计算,如业务日的计算、节假日处理等,则可以考虑使用`java.time`包的其他类或第三方库。 为了更深入理解这些类的使用方法和最佳实践,建议参考《Java8时间API实战:LocalDateLocalDateTime解析》。这份文档不仅涵盖了上述类的基本使用,还提供了丰富的代码示例和场景应用,有助于开发者在实践快速掌握和应用这些新API。 参考资源链接:[Java8时间API实战:LocalDateLocalDateTime解析](https://wenku.csdn.net/doc/5gup5xforu?spm=1055.2569.3001.10343)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值