
问题描述: 最近遇到一个bug,一个上线一年的项目,突然出现问题,通过Arthas排查日志,发现是因为获取年份错了,当前时间是2024.10.30,但是代码获取到的是2025.10.30
String currentDateString = DateUtil.format(new Date(), "YYYY-MM-dd");
// 当前时间是2024.10.30,代码打印2025.10.30
System.out.println(currentDateString);通过查阅资料,知道YYYY格式化后表示的是Week year,就是这天所在的周所属的年。而每年的第一周是怎么定义的呢?ISO 8601中给出的定义:本年第一个周四所在的那个星期,所以看看日历,2025年的第一个周四在2号,所以从2024.12.29~2025.04表示2025年的第一周,所以也就可以解释在2024.10.30通过YYYY获取到的为什么是2025

在一份oracle文档找到的解释: https://docs.oracle.com/javase/8/docs/api/java/text/SimpleDateFormat.html

所以获取日期需要使用yyyy来获取
String currentDateString = DateUtil.format(new Date(), "yyyy-MM-dd");
// 当前时间是2024.10.30,代码打印2024.10.30
System.out.println(currentDateString);
String currentDateString = DateUtil.format(new Date(), "YYYY-MM-dd");
// 当前时间是2024.10.30,代码打印2025.10.30
System.out.println(currentDateString);DateUtil是hutool的api,查看源码,本质也是通过SimpleDateFormat
