我试图将毫秒时间戳转换为XMLGregorianCalendar并返回,但我似乎得到了错误的结果.难道我做错了什么?看来我好几天了.
// Time stamp 01-Jan-0001 00:00:00.000
Long ts = -62135740800000L;
System.out.println(ts);
System.out.println(new Date(ts)); // Sat Jan 01 00:00:00 PST 1 .. Cool!
// to Gregorian Calendar
GregorianCalendar gc = new GregorianCalendar();
gc.setTimeInMillis(ts);
// to XML Gregorian Calendar
XMLGregorianCalendar xc = DatatypeFactory.newInstance().newXMLGregorianCalendar(gc);
// back to GC
GregorianCalendar gc2 = xc.toGregorianCalendar();
// to Timestamp
Long newTs = gc2.getTimeInMillis();
System.out.println(newTs); // -62135568000000 .. uh?
System.out.println(new Date(newTs)); // Mon Jan 03 00:00:00 PST 1 .. where did the extra days come from?
Run Code Online (Sandbox Code Playgroud)
有趣的是 - 它对于低至(大约)-10000000000000L(和正值)的值效果很好,但较大的负值会变得不一致。
如果打印出gc、xc和gc2,您可以看到问题出现在哪里(从 XMLGregorianCalendar 到 GregorianCalendar 的转换
gc: java.util.GregorianCalendar[time=-62135740800000 ... DAY_OF_WEEK=7
xc: 0001-01-01T08:00:00.000Z
gc2: java.util.GregorianCalendar[time=? ... DAY_OF_WEEK=5
Run Code Online (Sandbox Code Playgroud)
如果打印出 的字段xc,则会得到 1,1,1。
System.out.println(xc.getYear());
System.out.println(xc.getMonth());
System.out.println(xc.getDay());
Run Code Online (Sandbox Code Playgroud)
对于gc2,您得到 1,0,1 (与 匹配xc,因为 GregorianCalendar 中的月份是从零开始的)
System.out.println(gc2.get(gc2.YEAR));
System.out.println(gc2.get(gc2.MONTH));
System.out.println(gc2.get(gc2.DAY_OF_MONTH));
Run Code Online (Sandbox Code Playgroud)
然而,添加这 3 个println调用会改变打印输出gc2!-time=?输出gc2更改为time=-62135568000000- 因此通过查询对象触发了一些计算GregorianCalendar;该areFieldsSet属性也从 更改false为true。
两个 GregorianCalendar 的时区不同,但这并不能解释错误,即使您设置了明确的 TimeZone 和 Locale,该错误仍然存在。