博客
关于我
Java8日期格式化工具
阅读量:403 次
发布时间:2019-03-05

本文共 3889 字,大约阅读时间需要 12 分钟。

package com.freedom.demo.utils;import lombok.extern.slf4j.Slf4j;import org.apache.commons.lang3.StringUtils;import java.text.DateFormat;import java.text.ParseException;import java.text.SimpleDateFormat;import java.time.LocalDate;import java.time.LocalDateTime;import java.time.format.DateTimeFormatter;import java.util.Calendar;import java.util.Date;import java.util.HashMap;import java.util.Map;/** * @author tobebetter9527 * @description 处理日期工具,适用于java8新的日期和时间 * @create 2020/05/02 16:32 */@Slf4jpublic class DateUtil2 {       private DateUtil2() {       }    private static final String DATE_FORMAT = "yyyy-MM-dd";    private static final String DATETIME_FORMAT = "yyyy-MM-dd HH:mm:ss";    private static final ThreadLocal
> dateThreadLocal = new ThreadLocal<>(); /** * format LocalDate, yyyy-MM-dd * * @param localDateTime * @return */ public static String formatDate(LocalDateTime localDateTime) { return format(localDateTime, DATE_FORMAT); } /** * format LocalDate, yyyy-MM-dd * * @param localDate * @return */ public static String formatDate(LocalDate localDate) { return format(localDate, DATE_FORMAT); } /** * format formatDateTime, yyyy-MM-dd HH:mm:ss * * @param localDateTime * @return */ public static String formatDateTime(LocalDateTime localDateTime) { return format(localDateTime, DATETIME_FORMAT); } /** * format date * * @param localDateTime * @param pattern * @return */ public static String format(LocalDateTime localDateTime, String pattern) { if (localDateTime == null) { throw new IllegalArgumentException("date can't be null"); } return localDateTime.format(getDateFormat(pattern)); } /** * format date * * @param localDate * @param pattern * @return */ public static String format(LocalDate localDate, String pattern) { if (localDate == null) { throw new IllegalArgumentException("date can't be null"); } return localDate.format(getDateFormat(pattern)); } /** * parse date,yyyy-MM-dd * * @param dateStr * @return */ public static LocalDate parseDate(String dateStr) { return parseDate(dateStr, DATE_FORMAT); } /** * parse Date, yyyy-MM-dd HH:mm:ss * * @param dateStr * @return */ public static LocalDateTime parseDateTime(String dateStr) { return parseDateTime(dateStr, DATETIME_FORMAT); } /** * parse date * * @param dateStr * @param pattern * @return */ public static LocalDateTime parseDateTime(String dateStr, String pattern) { return LocalDateTime.parse(dateStr, getDateFormat(pattern)); } /** * parse date * * @param dateStr * @param pattern * @return */ public static LocalDate parseDate(String dateStr, String pattern) { return LocalDate.parse(dateStr, getDateFormat(pattern)); } /** * 同个线程,可以避免创建很多个DateFormat. * * @param pattern * @return */ private static DateTimeFormatter getDateFormat(String pattern) { // 校验入参 if (StringUtils.isBlank(pattern)) { throw new IllegalArgumentException("pattern can't be empty"); } // 获取DateFormat Map
dateFormatMap = dateThreadLocal.get(); if (dateFormatMap != null && dateFormatMap.containsKey(pattern)) { return dateFormatMap.get(pattern); } synchronized (dateThreadLocal) { if (dateFormatMap == null) { dateFormatMap = new HashMap<>(); } dateFormatMap.put(pattern, DateTimeFormatter.ofPattern(pattern)); dateThreadLocal.set(dateFormatMap); } return dateFormatMap.get(pattern); }}

转载地址:http://yphwz.baihongyu.com/

你可能感兴趣的文章
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>