当前位置:首页 > 每日看点

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

卡卷网1年前 (2025-01-19)每日看点314

“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.
  • 代码审查:在代码开发过程中,要进行严格的代码审查,特别是涉及到日期格式化的部分。审查人员要仔细检查格式化字符串,确保使用正确的年份表示方式,避免因粗心大意而引入错误.
  • 测试覆盖:在测试阶段,要设计全面的测试用例,涵盖各种边界情况,包括跨年日期、闰年等。通过自动化测试和手动测试相结合的方式,确保日期格式化功能在各种情况下都能正确运行.
  • 文档学习:开发者要加强对日期格式化相关文档的学习,了解不同格式化符号的含义和使用场景。在遇到不确定的情况时,及时查阅官方文档,避免盲目使用导致错误.

总结

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

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

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

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/10125.html

分享给朋友:

相关文章

逾期后支付宝微信被冻结,显示执保该怎么办?

这几天有朋友问我说,他的微信零钱突然的用不了,问我是不是被冻结了,问我该怎么办?是不是被起诉了?这个,那个,别慌,别慌,还是那句老话:有钱就去协商,没钱只能暂时不管!但是真不管,这个被冻结的微信怎么办呢?今天针对这个问题,我就给大家做一哥比…

怎么用游戏搬砖挣钱呢?

怎么用游戏搬砖挣钱呢?

今天,我把我多年操作的经验分享出来,以供各位老板们学习借鉴,胆小的老板就离开吧,心里承受能力太弱了,会刷新你的认知的。 有些新人在计算收益的时候,会以机器数来计算,其实是有误区的, 比如,一台机器一个月搞400元,平均每天搞13元钱,搞上1…

为什么我们一直在给B站充大会员但B站却一直处于亏损状态?

我讲一下离谱的真相吧,欢迎喷我。 很多人都觉得B站在赶走人才,赶走优秀的长视频创作者,也觉得知乎在这么做,是没错的。 确实在这么做。而原因很简单。 只有影响力很大的KOL才有商业价值。 (KOL是指“关键意见领袖”)而你说你是人才? 对不起…

为什么大家都说手机性能永远超不过PC?

最新的天玑9400牛逼吧,堪称PC级CPU,测试成绩16W功耗能跑9500分,1.8W能跑3000分,GPU也差不多是这个情况。 手机电池一般是4000-5000毫安时,电压3.7V。 也就是说,手机正常满载5W功耗下,这个电池能支持运行4…

中国芯片产量达1399亿颗,这意味着什么?

美国并不是没有明白人,只是特朗普不懂芯片产业的情况,冒冒失失在ZZ正确下,开启了对中国芯片的掐脖子,结果没掐死,反而让人练出了铁肺。 芯片是所有科技产业的上游,美国原本在上游呆得很舒服,靠英伟达、AMD、德州仪器、高通等这些几十年霸主地位的…

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。