-
听说又有兄弟因为用YYYY-MM-dd被锤了...
还记得去年分享过一篇日期格式化使用 YYYY-MM-dd 的潜在问题的文章不?
历史又重演了...
事故现场
我们来写个单元测试,重现一下这个问题。
测试逻辑:
-
创建两个日期格式化,一个是出问题的
YYYY-MM-dd
,另一个是正确用法yyyy-MM-dd
- 分别去格式化两个不同的日期: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年
本文首发于独立博客:http://blog.didispace.com/YYYY-MM-dd-2020-again/ ,更多技术干货欢迎收藏关注。
问题原因
为什么YYYY-MM-dd
格式化2020年12月27日的时候,会到2021年呢?
因为YYYY是week-based-year,表示:当天所在的周属于的年份,一周从周日开始,周六结束,只要本周跨年,那么这周就算入下一年。
所以2020年12月27日那天在这种表述方式下就已经到 2021 年了。
而当使用yyyy的时候,就还是 2020 年。
最后,自查一下你的程序是否有这样的问题吧!
原文:https://www.cnblogs.com/didispace/p/14210185.html
最新更新
iframe页面总是提示需要重新登录怎么办
mybatis(CRUD)
2021 全球程序员收入报告出炉,看完我真
Maven插件开发教程
引爆全球的 Log4j2 核弹级漏洞,JNDI 到底是
java 读写 ini 配置文件
动力节点-王妈妈Springboot教程(一)Xml 和
一文搞懂Flink Window机制
jdk8下载安装与配置环境变量(windows)
SpringBoot项目启动即执行某个方法
MongoDB常用命令(2)
MongoDB基本介绍与安装(1)
SQLServer触发器调用JavaWeb接口
SQL Server索引的原理深入解析
SqlServer2016模糊匹配的三种方式及效率问题
SQL中Truncate的用法
sqlserver 多表关联时在where语句中慎用tri
链接服务器读取Mysql---出现消息 7347,级别
SQL Server解惑——为什么你拼接的SQL语句换
MySQL视图了解一下
戏说HTML5
让 HTML5 来为你定位
Asp.net 微信H5唤起支付和支付回调
C# asp.net mvc 创建虚拟目录
浅薄的一些JAVA基础知识
【JS 逆向百例】网洛者反爬练习平台第一
springboot配置swagger2
160_Vue实战:路由模式,404,路由钩子
150_Vue实战:参数传递及重定向
140_Vue实战:路由嵌套