2012-07-06 88 views
0

我坚持在Android上运行这个例子:日期时间不一致

SimpleDateFormat sdf = new SimpleDateFormat("dd-mm-yyyy kkmm"); 
sdf.setTimeZone(TimeZone.getTimeZone(Time.TIMEZONE_UTC)); 

Date scheduledDateTime = sdf.parse(sms.getScheduledDateTime()); 

Log.i(TAG, "scheduledDateTime is : " + scheduledDateTime); // scheduledDateTime is : Fri Jan 06 23:58:00 HNEC 2012 
Log.i(TAG, "scheduledDateTime milli : " + scheduledDateTime.getTime()); // scheduledDateTime milli : 1325890680000 

Calendar calendar = Calendar.getInstance(); 
Calendar defaultTZCalendar = Calendar.getInstance(TimeZone.getDefault()); 
Calendar utcTZCalendar = Calendar.getInstance(TimeZone.getTimeZone(Time.TIMEZONE_UTC)); 

calendar.setTime(scheduledDateTime); 
defaultTZCalendar.setTime(scheduledDateTime); 
utcTZCalendar.setTime(scheduledDateTime); 

Log.i(TAG, "calendar : " + calendar.getTimeInMillis()); // calendar : 1325890680000 
Log.i(TAG, "defaultTZCalendar : " + defaultTZCalendar.getTimeInMillis()); // defaultTZCalendar : 1325890680000 
Log.i(TAG, "utcTZCalendar : " + utcTZCalendar.getTimeInMillis()); // utcTZCalendar : 1325890680000 

现在看看这个:

final long currentTimeMillis = System.currentTimeMillis(); 
Log.i(TAG, " currentTimeMillis is " + currentTimeMillis); // currentTimeMillis is 1341608182431 
Date d = new Date(currentTimeMillis); 
Log.i(TAG, " currentTimeMillis is " + d + " ::: d.getTime() = " + d.getTime()); // currentTimeMillis is Fri Jul 06 22:56:22 HAEC 2012 ::: d.getTime() = 1341608182431 

怎么可能有15713902431两者之间的这种差异日期看起来相同:Fri Jan 06 23:58:00 HNEC 2012 and Fri Jul 06 22:56:22 HAEC 2012

BTW,

HNEC是(法语)普通中央EUROP时间

HAEC是先进的中央EUROP时间(即DST)

感谢

回答

2

所有看起来很好,给我在端部。日期不“看起来一样”。一个在七月份,另一个在一月份。所以15713902431毫秒 - 接近182天 - 似乎完全合理。

现在对于为什么你数据没有被正确解析 - 您的格式被打破:

new SimpleDateFormat("dd-mm-yyyy kkmm"); 

注意“DD”和“YYYY”之间的“毫米”。 mm分钟,而不是个月

我强烈怀疑,你应该使用:

new SimpleDateFormat("dd-MM-yyyy kkmm"); 

那么你可能会在正确的一个月中获取值:)

+0

你先生是非常亲切,我很愚蠢。由于S.O.会在几分钟内接受你的答案。谢谢 – redochka 2012-07-06 21:44:31

相关问题