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

漫画编程

共 1421字,需浏览 3分钟

 ·

2021-01-14 11:18

还记得去年分享过一篇日期格式化使用 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日(周日)
具体代码如下:
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())); 
  } 
}

跑一下测试,可以看到输出结果如下:
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 年。


浏览 19
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报