工作6年了日期时间格式化还在写YYYY疯狂给队友埋雷

86,856 阅读2分钟

前言

哈喽小伙伴们好久不见,今天来个有意思的雷,看你有没有埋过。

正文

不多说废话,公司最近来了个外地回来的小伙伴,在广州工作过6年,也是一名挺有经验的开发。

他提交的代码被小组长发现有问题,给打回了,原因是里面日期格式化的用法有问题,用的SimpleDateFormat,但不知道是手误还是什么原因,格式用了YYYY-MM-dd。

这种写法埋了一个不大不小的雷。

用一段测试代码就可以展示出来问题

1.jpg

打印结果如下:

2.jpg

很明显,使用YYYY时,2023年变成了2024年,在正常情况下可能没问题,但是在跨年的时候大概率就会有问题了。

原因比较简单,与小写的yyyy不同,大写的YYYY表示一个基于周的年份。它是根据周计算的年份,而不是基于日历的年份。通常情况下,两者的结果是相同的,但在跨年的第一周或最后一周可能会有差异。

比如我如果换成2023-12-30又不会有问题了

3.jpg

另外,Hutool工具类本身是对Java一些工具的封装,DateUtil里面也有用到SimpleDateFormat,因此也会存在类似的问题。

4.jpg

避免这个问题的方法也十分简单,要有公用的格式类,所有使用日期格式的地方都引用这个类,这个类中就定义好yyyy-MM-dd想给的格式即可,这样就不会出现有人手误给大家埋雷了。

总结

  1. 日期时间格式统一使用yyyy小写;
  2. 日期格式要规定大家都引用定义好的工具类,避免有人手误打错。

最后再回头想一想,这种小问题并不会马上暴露出来,倘若没有被发现,到了明年元旦,刚好跨年的时候,是不是就要坑死一堆人了。