gpt4 book ai didi

Microsoft 时区的 java.time.zone.ZoneRulesProvider

转载 作者:搜寻专家 更新时间:2023-11-01 02:19:22 28 4
gpt4 key购买 nike

我正在针对一个外部 API 进行编码,该 API 将似乎是 Windows 时区描述的内容返回为字符串,例如“浪漫标准时间”,我需要将它们解析为 java ZoneId 或偏移量。这些值的列表可用 here .

java.time.ZoneId 文档指出:

Time-zone rules are defined by governments and change frequently. There are a number of organizations, known here as groups, that monitor time-zone changes and collate them. The default group is the IANA Time Zone Database (TZDB). Other organizations include IATA (the airline industry body) and Microsoft.

所以我的问题是,是否存在 javadoc 中提到的来自 Microsoft 的 java.time.zone.ZoneRulesProvider 的公共(public)实现?

我知道 Microsoft 时区和标准 IANA TZDB 之间存在关系,例如参见 this question .但我想知道的是,是否存在可以作为属性传入的 ZoneRulesProvider 的标准实现,如 javadoc 中所述:

If the system property java.time.zone.DefaultZoneRulesProvider is defined then it is taken to be the fully-qualified name of a concrete ZoneRulesProvider class to be loaded as the default provider, using the system class loader.

最佳答案

Java 文档是正确的,IANA、IATA 和 Microsoft 是时区信息的来源。然而,尽管可以为每个创建一个 ZoneRulesProvider,但据我所知,我不相信有任何标准的 ZoneRulesProvider 实现比 IANA 数据。如果愿意,可能会写一篇。

虽然有一个合理的解决方案。正如您提到的另一个问题,IANA 和 Microsoft 之间的时区映射是通过 windowsZones.xml file in the Unicode CLDR 维护的。 .您可以使用此数据将外部 API 返回的 Microsoft 时区 ID 转换为 IANA 时区名称。您可以直接使用它,也可以依赖为您提供此功能的库。一个好的图书馆选择是 International Components for Unicode (ICU) , 通过ICU4Jproject page 上找到实现. getIDForWindowsID 方法 ( docs here ) 使用 CLDR 数据提供翻译。

或者,如果您对外部 API 有任何影响,那么它返回的 Microsoft 时区 ID 很可能是使用 .NET 构建的。如果是这样,您可以鼓励该 API 的开发人员在他们的 API 结果中返回一个标准的 IANA 时区 ID(如果他们担心兼容性,可以作为辅助字段)。我的开源TimeZoneConverter库适用于此目的,并且还使用相同的 CLDR 数据。

请注意,IANA 时区 ID 已在 Microsoft 的多个领域中使用,包括 Linux/MacOS 上的 .NET Core、通过 Noda Time 等库的 .NET Framework、通用 Windows 平台 (UWP) 应用程序,以及其他人很少。 “Microsoft 时区”是历史产物,可以追溯到最早的 Windows NT 时代。通常应该鼓励开发人员使用 IANA 时区 ID,而不是 Microsoft 时区,特别是在面向外部的 API 中,以便与非 Windows 系统进行互操作。有关 Microsoft 时区的更多信息,请参阅 the timezone tag wiki .

另外 - 请注意,您链接到 Microsoft 时区列表的页面已有将近十年的历史,并且出于遗留目的而存在。索引列仅在 Windows CE 平台上使用过,其中一些时区已不复存在。我们不再将这些时区的列表发布为静态网页,因为数据变化太频繁了。您始终可以通过命令 TZUTIL/L 从任何 Windows 计算机获取列表​​,或者通过在 .NET 或 Powershell 中调用 TimeZoneInfo.GetSystemTimeZones(),或者通过检查注册表在 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Time Zones

完全披露:我帮助维护 Microsoft 的时区,以及几个用于 .NET 的开源时区库。

关于Microsoft 时区的 java.time.zone.ZoneRulesProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52857334/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com