Java DateFormat parse() doesn't respect the timezone

后端 未结 3 1107
小蘑菇
小蘑菇 2021-01-01 21:01
Calendar cal = Calendar.getInstance(TimeZone.getTimeZone("America/New_York"));
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss Z");
df.         


        
相关标签:
3条回答
  • 2021-01-01 21:14

    You're printing the result of calling Date.toString(), which always uses the default time zone. Basically, you shouldn't use Date.toString() for anything other than debugging.

    Don't forget that a Date doesn't have a time zone - it represents an instant in time, measured as milliseconds since the Unix epoch (midnight on January 1st 1970 UTC).

    If you format the date using your formatter again, that should come up with the same answer as before.

    As an aside, I would recommend the use of Joda Time instead of Date/Calendar if you're doing any significant amount of date/time work in Java; it's a much nicer API.

    0 讨论(0)
  • 2021-01-01 21:17

    DateFormat is an abstract class for date/time formatting subclasses which formats and parses dates or time in a language-independent manner. The date/time formatting subclass, such as SimpleDateFormat, allows for formatting (i.e., date -> text), parsing (text -> date), and normalization. The date is represented as a Date object or as the milliseconds since January 1, 1970, 00:00:00 GMT.

    From the spec, it return EPOCH time

    0 讨论(0)
  • 2021-01-01 21:21

    DateFormat.parse() is NOT a query (something that returns a value and doesn't change the state of the system). It is a command which has the side-effect of updating an internal Calendar object. After calling parse() you have to access the timezone either by accessing the DateFormat's Calendar or calling DateFormat.getTimeZone(). Unless you want to throw away the original timezone and use local time, do not use the returned Date value from parse(). Instead use the calendar object after parsing. And the same is true for the format method. If you are going to format a date, pass the calendar with the timezone info into the DateFormat object before calling format(). Here is how you can convert one format to another format preserving the original timezone:

        DateFormat originalDateFormat = new SimpleDateFormat("EEE MMM dd HH:mm:ss Z yyyy");
        DateFormat targetDateFormat = new SimpleDateFormat("EEE., MMM. dd, yyyy");
    
        originalDateFormat.parse(origDateString);
        targetDateFormat.setCalendar(originalDateFormat.getCalendar());
        return targetDateFormat.format(targetDateFormat.getCalendar().getTime());
    

    It's messy but necessary since parse() doesn't return a value that preserves timezone and format() doesn't accept a value that defines a timezone (the Date class).

    0 讨论(0)
提交回复
热议问题