当前位置:首页 > 每日看点 > 正文内容

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

卡卷网10个月前 (01-19)每日看点210

“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

分享给朋友:

相关文章

推荐几个问卷调查平台?

推荐几个问卷调查平台?

我给大家免费推荐一些市面上不多,且稳定的免费的问卷平台,这个在网上都是能够搜索到的,有的还是世界500钱企业,这里推荐的基本上都是上市的问卷公司了。上面都是可以免费去注册的,对外公开开放的,做完了直接奖励美刀的,不需要兑换卡什么的。Cint...

最让你震惊的网站有哪些?

压箱底的震惊来了,来波大的,一百个网站!这些都是我平时辛辛苦苦收集的,是真的牛逼,居然还有这种网站。1、实时地球网址:https://zoom.earth/实时图像每 10 分钟更新一次,提供风暴、天气预报、降水、火警等数据2、陕西博物馆...

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

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

苹果为什么不做千元机?

苹果为什么不做千元机?

第一步,打开苹果官网,注意是.com,不是.cn;第二步,点击iPhone,选择Compare iPhone;第三步,选择最新iPhone 15系列,查看起售价格,分别为$1199,$999,$799。这不妥妥的千元机吗,怎么苹果就不做千元...

马云也搞不明白:为什么现在用户偏爱微信支付,而不是支付宝?

这题我会,我教马云一招。你直接把你那破比支付宝的代码全删了,重新写一个。打开支付宝直接就是一个大大的支付码,然后右上角按一下就是扫一扫。你要是还想保留你的其他那些乱七八糟的功能,麻烦将他们全部做到下拉菜单里。你这么设计我不说你能干死微信,但...

为什么有人觉得华为mate60只值2000?

为什么有人觉得华为mate60只值2000?

你以为买Mate60的人真的傻?真的那么爱国?国庆前,我家那傻子加价800多买了一台Mate60,当时还被我骂他是傻子。可是他说一回到公司就被老板同事朋友看到,拿去反复查看,都在惊叹他这么快就买到新机。跟亲戚朋友聚会,别人一看就知道他买的是...

发表评论

访客

看不清,换一张

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