博客
关于我
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/

你可能感兴趣的文章
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>