将IST转换为GMT时,我遇到了一个奇怪的问题。除了下午5:30和下午6:30之外,转换工作正常。在此期间,而不是将时间转换为12:00:00,它将转换为00:00:00
答案 0 :(得分:0)
好的,所以我猜IST意味着印度标准时间;即GMT + 5:30。
下午5:30 IST将是12nn GMT,即使用传统的24小时制时钟的12:00:00。 (或称之为“铁路时间”。)
如果没有您的任何进一步意见,我最好的猜测是您在处理代码时遇到了一些错误(例如输入时间不是您认为的那样),或者语言环境设置有些奇怪这会影响时间的显示方式。
答案 1 :(得分:0)
我在这个答案中使用了24小时制,以保持清晰。
你确定你要从17:30 IST转换吗?如果你实际上正在转换05:30(即早上五点半),那将是格林尼治标准时间午夜。在24小时制的午夜时间是00:00,所以这一切都会加起来。
然而,这不会解释从06:30开始的转换,即格林尼治标准时间01:30。
答案 2 :(得分:0)
ZonedDateTime.of( 2017 , 1 , 23 , 17 , 30 , 0 , 0 , ZoneId.of( "Asia/Kolkata" ) )
.toInstant()
2017-01-23T12:00:00Z
在没有看到有问题的代码的情况下,无法准确回答这个问题。但我可以使用java.time类向您展示正确的现代代码。
“IST”是指印度标准时间,爱尔兰标准时间还是伊朗标准时间?鉴于示例数据,我猜India time。
以continent/region
的格式指定proper time zone name,例如America/Montreal
,Africa/Casablanca
或Pacific/Auckland
。切勿使用诸如EST
或IST
之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。
ZoneId z = ZoneId.of( "Asia/Kolkata" );
LocalDate localDate = LocalDate.of( 2017 , 1 , 23 );
LocalTime localTime = LocalTime.of( 17 , 30 ); // 5:30 PM.
ZonedDateTime zdt = ZonedDateTime.of( localDate , localTime , z );
要通过UTC镜头查看同一时刻,请提取Instant
。 Instant
类代表UTC中时间轴上的一个时刻,分辨率为nanoseconds(小数部分最多九(9)位)。
Instant instant = zdt.toInstant();
请参阅此code run live at IdeOne.com。
此时,印度的时间比UTC晚了五个半小时。因此,下午5:30 PM在加尔各答调整为UTC意味着减去5小时30分钟,这将我们带回UTC中午。所以你在结果中看到了。
zdt.toString():2017-01-23T17:30 + 05:30 [亚洲/加尔各答]
instant.toString():2017-01-23T12:00:00Z
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和& SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。