YYYY-MM-dd的时间格式你写过吗?

本文解析了在编程中使用 SimpleDateFormat 时,'YYYY-MM-dd'和'yyyy-MM-dd'格式的区别,特别关注了'YYYY'导致的周基年问题,以及实际日期转换中的表现和潜在错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

YYYY-MM-dd格式熟悉?

今早看了一点文章,关于时间格式化的问题,我们在开发的过程中经常需要将日期进行格式化,常见的形式是 2020-12-31这种格式的

 SimpleDateFormat df2 = new SimpleDateFormat("yyyy-MM-dd");

但是有人不小心写成这样了

System.out.println("YYYY-MM-dd = " + df1.format(c.getTime()));

这么写会出现什么问题呢?

SimpleDateFormat df1 = new SimpleDateFormat("YYYY-MM-dd");
        SimpleDateFormat df2 = new SimpleDateFormat("yyyy-MM-dd");

        Calendar c = Calendar.getInstance();

        // 2020年12月26日周六
        c.set(Calendar.DATE, 26);
        System.out.println("YYYY-MM-dd = " + df1.format(c.getTime()));
        System.out.println("yyyy-MM-dd = " + df2.format(c.getTime()));

输出结果为
在这里插入图片描述
这么看没有什么异常,如果日期变成 2020-12-27号的日期呢?

 		c.set(Calendar.DATE, 27);
        System.out.println("YYYY-MM-dd = " + df1.format(c.getTime()));
        System.out.println("yyyy-MM-dd = " + df2.format(c.getTime()));

输出结果是

在这里插入图片描述
查看了这篇文章说的原因是因为-

https://juejin.cn/post/6911874152953708558

因为YYYY是week-based-year,表示:当天所在的周属于的年份,一周从周日开始,周六结束,只要本周跨年,那么这周就算入下一年。

所以2020年12月27日那天在这种表述方式下就已经到 2021 年了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值