博客
关于我
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 自增id和UUID做主键性能分析,及最优方案
查看>>
Mysql 自定义函数
查看>>
mysql 行转列 列转行
查看>>
Mysql 表分区
查看>>
mysql 表的操作
查看>>
mysql 视图,视图更新删除
查看>>
MySQL 触发器
查看>>
mysql 让所有IP访问数据库
查看>>
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>
MySQL 证明为什么用limit时,offset很大会影响性能
查看>>
Mysql 语句操作索引SQL语句
查看>>
MySQL 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 通过查看mysql 配置参数、状态来优化你的mysql
查看>>
mysql 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>