Java中新增了日期处理类——LocalDate,它是一种高效的日期类,比起Date的复杂具有相当高的简洁性,主要有三种:
java.time.LocalDate ->只对年月日做出处理
java.time.LocalTime ->只对时分秒纳秒做出处理
java.time.LocalDateTime ->同时可以处理年月日和时分秒
首先通过代码看看LocalDate类的使用:
// 取当前日期:
LocalDate today = LocalDate.now(); // -> 2014-12-24
// 根据年月日取日期,12月就是12:
LocalDate crischristmas = LocalDate.of(2014, 12, 25); // -> 2014-12-25
// 根据字符串取:
LocalDate endOfFeb = LocalDate.parse("2014-02-28"); // 按照yyyy-MM-dd验证,02写成2都不行
LocalDate.parse("2014-02-29"); // 无效日期无法通过:抛出DateTimeParseException: Invalid date
int dayofMonth = today.getDayOfMonth();
// 今天是周几(**返回的是个枚举类型,需要再getValue()**)
int dayofWeek = today.getDayOfWeek().getValue();
// 今年是哪一年
int dayofYear = today.getDayOfYear();
通过上面这几个方法可以方便得到和构造符合yyyy-MM-dd标准的日期,在实际开发中还会频繁进行日期的类型转换和与数据库的交互,所以再展示其更强大的地方,使用TemporalAdjusters 类对日期进行修改
// 取本月第1天:
LocalDate firstDayOfThisMonth = today.with(TemporalAdjusters.firstDayOfMonth()); // 2018-04-01
// 取本月第2天:
LocalDate secondDayOfThisMonth = today.withDayOfMonth(2); // 2018-04-02
// 取本月最后一天,再也不用计算是28,29,30还是31:
LocalDate lastDayOfThisMonth = today.with(TemporalAdjusters.lastDayOfMonth()); // 2018-04-30
// 取下一天:
LocalDate firstDayOfNextMonth = lastDayOfThisMonth.plusDays(1); // 变成了2018-05-01
// 取2017年1月第一个周一:
LocalDate firstMondayOf2019 = LocalDate.parse("2019-01-01").with(TemporalAdjusters.firstInMonth(DayOfWeek.MONDAY)); // 2019-01-07
是不是很方便,比如取本月最后一天时根本无需判断是哪一月,它已经帮你实现了。放几个常用的API
LocalTime只包含时间,以前用java.util.Date怎么才能只表示时间呢?答案是,假装忽略日期。
//LocalTime包含毫秒:
LocalTime now = LocalTime.now(); // 11:09:09.240
//清除毫秒数:
LocalTime now = LocalTime.now().withNano(0)); // 11:09:09
//构造时间:
LocalTime zero = LocalTime.of(0, 0, 0); // 00:00:00
LocalTime mid = LocalTime.parse("12:00:00"); // 12:00:00
时间也是按照ISO格式识别,但可以识别以下3种格式:
12:00
12:01:02
12:01:02.345
同样,放一些常用API
date -> LocalDate
time -> LocalTime
timestamp -> LocalDateTime
写个小例子实现以下插入各种类型的时间
package com.bm.db;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
public class DateTest {
public static void main(String[] args) {
// String datetime = 2018-04-30
// TODO Auto-generated method stub
String sql="insert into time(info,timestamp,date,time,datetime) values ('dabai','"+LocalDateTime.now()+"','"
+LocalDate.now()+"','"+LocalTime.now()+"','"+LocalDateTime.now().withNano(0)+
"')";
int i =mysqlUtil.update(sql);
}
}
注意:timestamp会在你每次修改此条记录后自动根据系统时间修改。所以timestamp适合记录最后更改的时间,datetime适合记录开始的时间,timestamp有效时间1970-01-01 00:00:00 到 2037年,超过的自动置0.而datetime有效时间’1000-01-01 00:00:00’到’9999-12-31 23:59:59’.
另外,使用timestamp会伴随时区问题,暂时没遇到,以后再解决。
下面是另外一个很常见的问题。
说到转换格式,有SimpleDateFormat和DateFormat,但是它们两者都是线程不安全的!啥情况下会有这样的问题呢?如果我们为了实现日期转换这样的工具,每次都new一个对象,但是用完了就不用了,就造成了浪费,为此我们会将它写成单例的,但是单例的同时,一个对象供多个线程使用的时候,就会出现线程安全的问题。这个时候就需要这个新的jdk8出的DateTimeformatter这个类。
字符串->类
写在前面。如果是很工整的格式,yyyy-MM-dd 这种日期格式字符串,直接用LocalDate.parse()进行转换就行了,相对应的时间也是。既有时间又有日期的用DateTimeformatte这个类就行。
String time = "1997-01-31 18:39:20";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
LocalDateTime dateTime =LocalDateTime.from(formatter.parse(time));
String time = "1997-01-31 18:39:20";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
LocalDateTime dateTime = LocalDateTime.parse(time,formatter);
类->字符串
如果是LocalDate这种标准格式的,直接toString就可以了,-
如果是LocalTime这种格式的,toString会附带纳秒值21:06:30.760163,
这个时候你可以使用日期格式器,或者这样
LocalTime time1 = LocalTime.now().withNano(0),把纳秒直接清0.
如果是LocalDateTime,这个时候是需要一个日期转换器的。才能由时间+日期->想要的时间,
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
LocalDateTime nowTime = LocalDateTime.now();
String result = nowTime.format(formatter);
到这吧。
参考:https://blog.csdn.net/qq_41376740/article/details/81292504