博客
关于我
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中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>