It helps to understand the difference between LocalDateTime and ZonedDateTime. What you really want is a ZonedDateTime
. If you wanted to remove the timezone from the string representation, you would convert it to a LocalDateTime
.
What you're looking for is:
ZonedDateTime swissZonedDateTime = withZoneSameInstant(ZoneId.of("Europe/Zurich"));
LocalDateTime - this is basically a glorified string representation of a Date
and Time
; it is timezone agnostic, which means it does not represent any point in time on a timeline
Instant - this is a millisecond representation of time that has elapsed since EPOCH. This represents a specific instant in time on a timeline
ZonedDateTime - this also represents an instant in time on a timeline, but it represents it as a Date
and Time
with a TimeZone
.
The code below illustrates how to use all 3.
LocalDateTime localDateTime = LocalDateTime.of(2018, 10, 25, 12, 00, 00); //October 25th at 12:00pm
ZonedDateTime zonedDateTimeInUTC = localDateTime.atZone(ZoneId.of("UTC"));
ZonedDateTime zonedDateTimeInEST = zonedDateTimeInUTC.withZoneSameInstant(ZoneId.of("America/New_York"));
System.out.println(localDateTime.toString()); // 2018-10-25T12:00
System.out.println(zonedDateTimeInUTC.toString()); // 2018-10-25T12:00Z[UTC]
System.out.println(zonedDateTimeInEST.toString()); // 2018-10-25T08:00-04:00[America/New_York]
If you were to compare the Instant
values of both ZonedDateTimes
from above, they would be equivalent because they both point to the same instant in time. Somewhere in Greenwich (UTC timezone), it is noon on October 25th; at the same time, in New York, it would be 8 am (America/NewYork timezone).
ZoneId
toLocalDate.now()
too to obtain predictable results. It is never the same date everywhere on the globe. – Ethnocentrism