java – 为什么时区模式“OOOO”没有显示完整的GMT 00:00偏移格式?

前端之家收集整理的这篇文章主要介绍了java – 为什么时区模式“OOOO”没有显示完整的GMT 00:00偏移格式?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

这是一个错误还是一个功能

DateTimeFormatter JavaDoc明确指出当我在格式化程序中使用OOOO模式时,应使用完整形式的本地化时区(强调我的):

Four letters outputs the full form,which is localized offset text,such as ‘GMT,with 2-digit hour and minute field,optional second field if non-zero,and colon,for example ‘GMT+08:00’.

但如果时间是格林尼治标准时间0:

DateTimeFormatter formatter = DateTimeFormatter.ofPattern("EEE yyyy.MM.dd HH:mm:ss.SSS OOOO");

String timestamp = OffsetDateTime.ofInstant(Instant.now(),ZoneOffset.UTC).format(formatter);
System.out.println(timestamp);

这是输出

Mon 2019.02.25 22:30:00.586 GMT

预期:

Mon 2019.02.25 22:30:00.586 GMT+00:00
最佳答案
一个bug?我们似乎同意观察到的行为与文档不一致(或者至少您必须对文档进行非常有创意的阅读以使其匹配).

一项功能?据我所知,观察到的行为在某些时候是有意识的决定. DateTimeFormatterBuilder中私有内部类LocalizedOffsetIdPrinterParser的源代码包含if(totalSecs!= 0){在打印小时,分钟和秒之前.它看起来不像复制粘贴错误,因为完全相同的代码行在文件中没有其他地方(偏移0在许多地方被特别处理,但我不知道其他地方完全被遗漏).

在Java 8格式模式OOOO上既不解析GMT也不解析GMT 00:00,这必须是一个bug.它已在Java 11中修复.在Java 11 OOOO上单独解析GMT就好了,所以他们必须认为这是可接受的(尽管它也解析GMT 00:00和GMT-00:00).

您可以考虑使用Oracle和/或OpenJDK提交错误(我不确定这些天的正确位置).他们是否会拒绝它,修复文档或修复代码 – 我不敢尝试猜测.

解决方法:’GMT’xxx

Anyway,I want my +00:00 somehow.

DateTimeFormatter formatter = DateTimeFormatter.ofPattern("EEE yyyy.MM.dd HH:mm:ss.SSS 'GMT'xxx");

Wed 2019.02.27 08:46:43.226 GMT+00:00

猜你在找的Java相关文章