Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Which date class should I use in Java 8?

Tags:

There is a whole set of date's classes in Java 8:

  • java.time.LocalDateTime;
  • java.time.ZonedDateTime;
  • java.time.Instant;
  • java.time.OffsetDateTime;
  • java.sql.Timestamp;
  • java.util.Date.

I already passed over their JavaDocs and paid attention that all these classes contain all the methods I need. Thus, for the moment, I can select them randomly. But I guess that there is some reason why there are 6 separate classes and each of them is dedicated to the specific purpose.

Technical information & requirements:

  1. The input is in String, which is converted to one of these date formats.
  2. I don't need to display the time zones but when I compare two dates it's important to be capable to compare correctly the time in New York and in Paris.
  3. The precise level is seconds, there is no need to use milliseconds.
  4. The required operations:
    • find max/min date;
    • sort objects by date;
    • calculate date & time period (difference between two dates);
    • insert objects to MongoDB and retrieve them from a db by date (e.g. all objects after specific date).

My questions:

  1. Which aspects should I bear in mind in order to choose the optimal format among these four options from the performance & maintainability points of view?
  2. Is there any reason why I should avoid some of these date classes?
like image 653
Mike Avatar asked Feb 09 '16 20:02

Mike


People also ask

Which date class should I use in Java?

Using LocalDate, LocalTime and LocalDateTime. The most commonly used classes are LocalDate, LocalTime and LocalDateTime.

What class is date and time in Java 8?

SimpleDateFormat: It is a class that is used to format and parse the dates in a predefined manner or user defined pattern. java. util.

Should I use Java Util date or Java SQL date?

util. Date class which represents date without time information and it should be used only when dealing with databases. To conform with the definition of SQL DATE, the millisecond values wrapped by a java. sql.

Should I use SQL date or UTIL date?

sql. Date just represent DATE without time information while java. util. Date represents both Date and Time information.


1 Answers

Each one of the Date classes are for specific purposes:

  • If you want to use your Date in an SQL/JDBC context, use the java.sql.Timestamp.

  • java.util.Date is the old Java API, it is not thread safe, you can difficultly handle time zoning, and on the top of all, it is poorly designed: one simple uniformity is that months start from 1 while days start from 0.

  • java.time.LocalDateTime is an immutable date-time object that represents a date-time, often viewed as year-month-day-hour-minute-second, which you need exactly.

  • java.time.ZonedDateTime class stores all date and time fields, so you can use it to deal with values like: 27th January 1990 at 15:40.30.123123123 +02:00 in the Europe/Paris time-zone.

To do your task, the ZonedDateTime class handles conversion from the local time-line of LocalDateTime to the instant time-line of Instant(which models a single instantaneous point on the time-line). The difference between the two time-lines, represented by a ZoneOffset, is the offset from UTC/Greenwich.

To calculate duration and period: there is the java.time.Duration which is a time-based amount of time, such as '20.5 seconds', and java.time.Period, which is a date-based amount of time (like: 26 years, 2 months and 2 days).

To get max and min dates, you can use the Java 8 lambdas in something like:

Date maxDate = list.stream().map(yourInstance -> yourInstance.date).max(Date::compareTo).get(); Date minDate = list.stream().map(yourInstance -> yourInstance.date).min(Date::compareTo).get(); 
like image 179
Maouven Avatar answered Oct 15 '22 23:10

Maouven