一、新日期类
1.1 新日期类简介
Java 8 在 java.time 包下提供了很多新的 API,以下为两个比较重要的API:
-
Local(本地) − 简化了日期时间的处理,没有时区的问题。
-
Zoned(时区) − 通过指定的时区处理日期时间。
新的java.time包涵盖了所有处理日期,时间,日期/时间,时区,时刻(instants),过程 (during)与时钟(clock)的操作。
1.2 为什么还需要新的日期类
Java 8通过发布新的Date-Time API 来进一步加强对日期与时间的处理。 在旧版的 Java中,日期时间 API 存在诸多问题,其中有:
-
非线程安全 − java.util.Date 是非线程安全的,所有的日期类都是可变的,这是Java日期类最大的问题之一。
-
设计很差 − Java的日期/时间类的定义并不一致,在java.util和java.sql的包中都有日期类,此外用于格式化和解析的类在java.text 包中定义。java.util.Date同时包含日期和时间,而java.sql.Date仅包含日期,将其纳入java.sql包并不合理。另外这两个类都有相同的名字,这本身就是一个非常糟糕的设计。
-
时区处理麻烦 − 日期类并不提供国际化,没有时区支持,因此Java引入了 java.util.Calendar和java.util.TimeZone类,但他们同样存在上述所有的问题。
1.3 本地化日期时间API
package cn.tedu.newtime;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
/**
* Java8新日期类的案例演示
* 当前案例是不区分时区的本地时间
* @author cjn
*
*/
public class LocalDemo01 {
public static void main(String[] args) {
/*
* LocalDateTime:年月日时分秒
* LocalDate:年月日
* LocalTime:时分秒
*/
LocalDateTime currentTime = LocalDateTime.now();
System.out.println("当前的日期时间为:" + currentTime);
//获取日期
LocalDate date = currentTime.toLocalDate();
LocalDate date2 = LocalDate.now();
System.out.println("当前日期为:" + date);
System.out.println("当前日期为:" + date2);
//获取时间
LocalTime time = currentTime.toLocalTime();
LocalTime time2 = LocalTime.now();
System.out.println("当前时间为:" + time);
System.out.println("当前时间为:" + time2);
//获取年
System.out.println(currentTime.getYear());
//获取月
System.out.println(currentTime.getMonth());
//获取日
System.out.println(currentTime.getDayOfMonth());
//获取小时
System.out.println(currentTime.getHour());
//获取分钟
System.out.println(currentTime.getMinute());
//获取秒
System.out.println(currentTime.getSecond());
/*
* 设置日期和时间 2002年12月30日T9:00:00
*/
LocalDateTime date3 = currentTime.withYear(2002)
.withMonth(12).withDayOfMonth(30).withHour(9).withMinute(0).withSecond(0);
System.out.println(date3);
/*
* 设置小时
*/
LocalTime time3 = currentTime.withHour(17).toLocalTime();
System.out.println(time3);
System.currentTimeMillis();
//将字符串转换为日期时间
String timeStr = "08:00:01";
LocalTime time4 = LocalTime.