New Date & Time API in Java 8

前端 未结 2 1635
滥情空心
滥情空心 2021-02-13 22:51

On this page i read the following:

To do calculations with dates, it is also very easy. Probably the best improvement compared to the current situation with Java < 1.

2条回答
  •  时光说笑
    2021-02-13 23:26

    With Java < 8, you would need to write something like:

    Calendar cal = Calendar.getInstance();
    cal.set(Calendar.HOUR, cal.get(Calendar.HOUR) + 2);
    

    vs. with Java 8:

    LocalTime now = LocalTime.now();
    LocalTime later = now.plus(2, HOURS);
    

    The improvements are essentially on

    • readability:
      • Calendar.getInstance() is not very well named: it is hard to tell which instance you are getting without reading the Javadoc. LocalTime.now() is quite self-describing: you get a time and it is now.
      • To offset a date, you call an offsetting method (plus) whereas with the Calendar API, you have to manually change the fields of the object (in this example, the hour) which is error prone.
    • ease of use (see for example the table towards the bottom of this page for a comparison):
      • the Calendar API is complicated to use because it mixes concepts, such as a simple date (June 26th 2015) and an instant in time (June 26th 2015 at 10am UTC) - there isn't a class for the former concept
      • The new Time API has a clear separation between the various date/time concepts
    • safety:
      • The Calendar API is not safe: nothing prevents you from writing cal.set(123, 2) which would throw a not-so-helpful ArrayOutOfBoundsException. The new API uses enums which solves that problem.
      • The new API uses immutable objects, which makes it thread safe.

    Overall, the new API is significantly inspired from jodatime which has been the preferred Java Date API for quite some time now. You can also read this detailed comparison of Java (<1.8) date vs. JodaTime (most of it should apply to the Java 8 Date API).

提交回复
热议问题