Usage of various classes of Date Time API

The following example also has an explanation required for understanding the example within it.

import java.time.Clock;
import java.time.Duration;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.util.TimeZone;
public class SomeMethodsExamples {

* Has the methods of the class {@link LocalDateTime}
public static void checkLocalDateTime() {
    LocalDateTime localDateTime =;
    System.out.println("Local Date time using static now() method ::: >>> " localDateTime);
     LocalDateTime ldt1 =            "AET")));
     System.out.println("LOCAL TIME USING now(ZoneId zoneId) method ::: >>>>"ldt1);
     LocalDateTime ldt2 =
     System.out.println("Local TIME USING now(Clock.system(ZoneId.of())) ::: >>>> "ldt2);
     System.out.println("Following is a static map in ZoneId             
     class which has mapping of short timezone names to their Actual timezone names");

This has the methods of the class {@link LocalDate}
public static void checkLocalDate() {
     LocalDate localDate =;
     System.out.println("Gives date without Time using now()              
method. >> "localDate);
     LocalDate localDate2 ="ECT")));
      System.out.println("now() is overridden to take ZoneID as parametere using this we can get the same date under different timezones. >> "localDate2);
*  This has the methods of abstract class {@link Clock}. Clock can be used
*  for time which has time with {@link TimeZone}.
public static void checkClock() {
       Clock clock = Clock.systemUTC();
       // Represents time according to ISO 8601
        System.out.println("Time using Clock class : " + clock.instant()); } 
*  This has the {@link Instant} class methods.
public static void checkInstant() {
    Instant instant =;
    System.out.println("Instant using now() method :: " + instant);
    Instant ins1 =;
    System.out.println("Instants using now(Clock clock) :: " + ins1);
*This class checks the methods of the {@link Duration} class.
public static void checkDuration() {
     // toString() converts the duration to PTnHnMnS format according to ISO
    // 8601 standard. If a field is zero its ignored.
    // P is the duration designator (historically called "period") placed at
    // the start of the duration representation.
    // Y is the year designator that follows the value for the number of
   // years.
   // M is the month designator that follows the value for the number of
  // months.
  // W is the week designator that follows the value for the number of
  // weeks.
  // D is the day designator that follows the value for the number of
  // days.
  // T is the time designator that precedes the time components of the
  // representation.
  // H is the hour designator that follows the value for the number of
  // hours.
  // M is the minute designator that follows the value for the number of
  // minutes.
  // S is the second designator that follows the value for the number of
  // seconds.
  *Shows Local time without date. It doesn't store or represenet        
     a date and
  *time. Instead its a representation of Time like clock on the wall.
  / public static void checkLocalTime() { LocalTime localTime =  ; System.out.println("LocalTime :: " +      localTime); } 
 *A date time with Time zone details in ISO-8601 standards.
  public static void checkZonedDateTime() {
     ZonedDateTime zonedDateTime =

Date Time Formatting

Before Java 8, there was DateFormat and SimpleDateFormat classes in the package java.text and this legacy code will be continued to be used for some time.

But, Java 8 offers a modern approach to handling Formatting and Parsing.

In formatting and parsing first, you pass a String object to DateTimeFormatter, and in turn, use it for formatting or parsing.

Related Article: Dates and Time (java.time.*)

import java.time.; import java.time.format.;
class DateTimeFormat
    public static void main(String[] args) {
        String pattern = "d-MM-yyyy HH:mm";
        DateTimeFormatter dtF1 =                    
        LocalDateTime ldp1 = LocalDateTime.parse("2014-03-25T01:30"), //Default format
        ldp2 = LocalDateTime.parse("15-05-2016 13:55",dtF1); //Custom format
        System.out.println(ldp1 + "\n" + ldp2); //Will be printed in Default format
        DateTimeFormatter dtF2 = DateTimeFormatter.ofPattern("EEE d, MMMM, yyyy HH:mm");
        DateTimeFormatter dtF3 =                            
        LocalDateTime ldtf1 =;
        System.out.println(ldtf1.format(dtF2) +"\n"+ldtf1.format(dtF3));

An important notice, instead of using Custom patterns, it is good practice to use predefined formatters. Your code looks more clear and usage of ISO8061 will definitely help you in the long run.

Simple Date Manipulations

Get the current date.

Obtain yesterday’s date.

LocalDate y =;

Get tomorrow’s date

LocalDate t =;

Get a specific date.

LocalDate t = LocalDate.of(1974, 6, 2, 8, 30, 0, 0);

In addition to the plus and minus methods, there are a set of “with” methods that can be used to set a particular field on a LocalDate instance.;

The example above returns a new instance with the month set to June (this differs from java.util.Date where setMonth was indexed a 0 making June 5).

Because LocalDate manipulations return immutable LocalDate instances, these methods may also be chained together.

LocalDate ld =;

This would give us tomorrow’s date one year from now.

Leave a Comment