前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >听说又有兄弟因为用YYYY-MM-dd 被锤了...

听说又有兄弟因为用YYYY-MM-dd 被锤了...

作者头像
程序猿DD
发布2023-04-04 15:15:53
2840
发布2023-04-04 15:15:53
举报
文章被收录于专栏:程序猿DD

还记得去年分享过一篇日期格式化使用 YYYY-MM-dd 的潜在问题(链接如下:http://blog.didispace.com/something-about-YYYY-MM-dd/)的文章不?

历史又重演了...

事故现场

我们先来写个单元测试,重现一下这个问题。

测试逻辑:

  • 1、创建两个日期格式化,一个是出问题的YYYY-MM-dd,另一个是正确用法yyyy-MM-dd
  • 2、分别去格式化两个不同的日期:2020年12月26日(周六),2020年12月27日(周日)

具体代码如下:

代码语言:javascript
复制
public class Tests {
  @Test 
  public void test() throws Exception { 
    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())); 
    
    // 分割线 
    System.out.println("========================"); 
    // 2020年12月27日 周日 
    c.add(Calendar.DATE, 1); 
    System.out.println("YYYY-MM-dd = " + df1.format(c.getTime())); 
    System.out.println("yyyy-MM-dd = " + df2.format(c.getTime())); 
  } 
}

跑一下测试,可以看到输出结果如下:

代码语言:javascript
复制
YYYY-MM-dd = 2020-12-26 
yyyy-MM-dd = 2020-12-26 
======================== 
YYYY-MM-dd = 2021-12-27 
yyyy-MM-dd = 2020-12-27
  • 2020年12月26日(周六),两种格式化都正确
  • 2020年12月27日(周日),YYYY-MM-dd出了问题,年份到了2021年

问题原因

为什么YYYY-MM-dd格式化2020年12月27日的时候,会到2021年呢?

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

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

而当使用yyyy的时候,就还是 2020 年。

最后,自查一下你的程序是否有这样的问题吧!

长按识别上方二维码,关注公众号:后端面试那些事

回复“报告”,获取你的GitHub年度报告!

夜宵是福利?那为什么不能随便吃?浅谈华为员工夜宵事件

2020-12-29

赠书:“替代Linux”?!全球技术海啸来临!

2020-12-29

Payment Spring Boot 1.0.2.RELEASE 发布,接入微信支付分、先享卡功能

2020-12-29

卧槽,QQ号也能改了!!!赶紧来改!宇宙唯一ID赶紧来抢注!

2020-12-28

美滋滋的开源数据库模型建模工具!

2020-12-28

想不想别人叫你爸爸?刚更新的微信红包,这玩法也太骚了吧

2020-12-27

扫一扫,关注我

知晓前沿科技,领略技术魅力

加入 Spring 技术学习群

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-12-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序猿DD 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 事故现场
  • 问题原因
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档