卡卷网
当前位置:卡卷网 / 每日看点 / 正文

yyyy-mm-dd日期格式跟yyyy-m-d有什么区别?

作者:卡卷网发布时间:2025-01-19 20:34浏览数量:147次评论数量:0次

“YYYY-MM-dd”格式陷阱

前言

yyyy-mm-dd日期格式跟yyyy-m-d有什么区别?  第1张

在元旦假期后的第一个工作日,我正准备买年货,却在使用一款 App 时意外发现了一个令人哭笑不得的 bug:我明明选择的是 2024 年 12 月 31 日出发,可 App 上显示的日期却变成了 2025 年 12 月 31 日。

一时间,我惊慌失措,以为自己下错了订单,甚至半开玩笑地想,是不是该把程序员拉去“祭天”了。

但转念一想,这种错误可能源于程序员在日期格式化时的粗心大意。

我以前学 Java 时就曾留意过这个问题,既然有程序员可能因此“背锅”,那我有必要把这个问题拿出来好好说说,希望能帮助大家避免类似的失误,毕竟这种问题在常规测试中确实难以被发现.

日期格式化陷阱剖析

先来看一段 Java 代码:

public class DateTest { public static void main(String[] args) { Calendar calendar = Calendar.getInstance(); calendar.set(2024, Calendar.AUGUST, 31); Date strDate = calendar.getTime(); DateFormat formatUpperCase = new SimpleDateFormat("yyyy-MM-dd"); System.out.println("2024-08-31 to yyyy-MM-dd: " + formatUpperCase.format(strDate)); formatUpperCase = new SimpleDateFormat("YYYY-MM-dd"); System.out.println("2024-08-31 to YYYY/MM/dd: " + formatUpperCase.format(strDate)); } }

这段代码的目的是将日期 2024-08-31 分别按照 yyyy-MM-dd 和 YYYY-MM-dd 的格式进行格式化输出。

运行结果如下:

2024-08-31 to yyyy-MM-dd: 2024-08-31 2024-08-31 to YYYY/MM/dd: 2024-08-31

从结果来看,两种格式化方式在这个日期下似乎没什么区别。

但当我们把日期改为 2024-12-31 时,情况就大不相同了:

calendar.set(2024, Calendar.DECEMBER, 31);

此时的运行结果是:

2024-12-31 to yyyy-MM-dd: 2024-12-31 2024-12-31 to YYYY-MM-dd: 2025-12-31

问题出现了!同样是表示年份的 y 和 Y,在跨年日期时却产生了截然不同的结果。

这绝非小事,用户看到这样的日期显示,肯定会一头雾水,甚至产生误会。

但我们作为开发者,绝不能懵懂无知,必须立刻查阅相关文档,搞清楚其中的奥妙.

y 和 Y 的区别

在 Java 的日期格式化中,y 和 Y 都是用来表示年份的,但它们有着本质的区别:

y 代表的是“year-of-era”,即“正正经经的年”,它严格按照公历纪年法来计算年份,从元旦(1 月 1 日)开始,到年末(12 月 31 日)结束。

因此,使用 yyyy 格式化 2024-12-31 时,输出结果是 2024-12-31,符合我们的常规认知.

Y 代表的是“week-based-year”,即“基于周的年份”。

它的计算方式与我们平时理解的年份有所不同,它是根据 ISO 周日历体系来确定的。

ISO 周日历规定,每年的第一周必须包含该年的第一个周四。

也就是说,如果某年的第一天(1 月 1 日)是周一、周二或周三,那么这一天会属于上一年的最后一周;如果 1 月 1 日是周四或之后的日期,那么这一天才会属于当年的第一周。

因此,当一周跨越了年份,而这周的大部分日期属于下一年时,使用 YYYY 格式化日期就会显示下一年的年份。

以 2024 年 12 月 31 日为例,这一天是周二,而 2025 年的第一周是从 2024 年 12 月 30 日(周一)开始的,所以使用 YYYY 格式化 2024-12-31 时,输出结果是 2025-12-31,因为它属于 2025 年的第一周.

如何避免日期格式化错误

为了避免在日期格式化时出现类似的错误,我们可以采取以下措施:

  • 明确需求:在进行日期格式化之前,首先要明确业务需求,确定是要严格按照公历纪年法来表示年份,还是要根据 ISO 周日历来表示年份。如果是前者,就使用 yyyy;如果是后者,才使用 YYYY.
  • 代码审查:在代码开发过程中,要进行严格的代码审查,特别是涉及到日期格式化的部分。审查人员要仔细检查格式化字符串,确保使用正确的年份表示方式,避免因粗心大意而引入错误.
  • 测试覆盖:在测试阶段,要设计全面的测试用例,涵盖各种边界情况,包括跨年日期、闰年等。通过自动化测试和手动测试相结合的方式,确保日期格式化功能在各种情况下都能正确运行.
  • 文档学习:开发者要加强对日期格式化相关文档的学习,了解不同格式化符号的含义和使用场景。在遇到不确定的情况时,及时查阅官方文档,避免盲目使用导致错误.

总结

日期格式化看似是一个小问题,但一旦出错,就可能给用户带来极大的困扰,甚至影响整个项目的进度和质量。

因此,作为开发者,我们必须高度重视这个问题,从需求明确、代码审查、测试覆盖和文档学习等多方面入手,确保日期格式化的准确性,为用户提供稳定可靠的软件产品。

– 欢迎点赞、关注、转发、收藏【我码玄黄】,各大平台同名。

END

免责声明:本文由卡卷网编辑并发布,但不代表本站的观点和立场,只提供分享给大家。

卡卷网

卡卷网 主页 联系他吧

请记住:卡卷网 Www.Kajuan.Net

欢迎 发表评论:

请填写验证码