写这篇博文是记录下跨年的 bug。作者:兔子托尼啊 链接:
https://zhuanlan.zhihu.com/p/101150248
去年隔壁组的小伙伴就是计算两个日期之间距离的天数,因为跨年的起因计算有误。
过后测试组的小姐姐也没有模仿进去这种场景,导致上生产环境间接影响线上的数据。
明天逛技术论论坛正好遇到 Java 日期的操作 bug。
1 yyyy 和 YYYY
别看字,看代码
输入后果:
仔细的同学应该发现了 2019-12-31 用 YYYY/MM/dd 此刻变成了 2020/12/31
??为何呢?
YYYY 这么大的能耐,能跑到 2020 年代去?
我 2019 年底买的货色,你如果用 YYYY 来格式化出库日期,我是不是失去 2020 年底能力收到货?此 bug 问题挺大的呀!
YYYY 到底是何方妖怪? 👺
Java’s DateTimeFormatter pattern “YYYY” gives you the week-based-year, (by default, ISO-8601 standard) the year of the Thursday of that week.
例子:
上面就是用 YYYY 格式化代码
- 12/29/2019 将会格式化到 2019 年 这一周还属于 2019 年
- 12/30/2019 将会格式化到 2020 年 这一周曾经属于 2020 年
看字谈话 YYYY,week-based year 是 ISO 8601 规定的。
2019-12-31 号这一天,安周算年份曾经属于 2020 年了,格式化之后就变成 2020 年,前面的月份日期不变。
2 dd 和 DD
输入后果:
看到没有?
最初的 3 个日期都谬误了,这里的大写的 DD 代表的是处于这一年中那一天,不是处于这个月的那一天。
小伙伴们肯定要记住了不要犯相似的谬误。
3、论断
YYYY 和 yyyy 不一样的,DD 和 dd 也是不一样要切记。
逆锋起笔
是一个专一于 IT 互联网编程的平台,以分享java
、Python
、大厂动静
、学习资源
为主,关注即可支付 23 种编程语言的精选视频和大佬们举荐的电子版学习材料!