fix bug.
parent
59f5a1d17b
commit
522dbd3a32
|
@ -9,31 +9,20 @@ import java.time.ZonedDateTime;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import xyz.zhouxy.plusone.commons.collection.SafeConcurrentHashMap;
|
||||||
|
|
||||||
public class DateTimeUtil {
|
public class DateTimeUtil {
|
||||||
|
|
||||||
private static final MapWrapper<String, DateTimeFormatter> DATE_TIME_FORMATTER_CHCHE = MapWrapper
|
private static final MapWrapper<String, DateTimeFormatter> DATE_TIME_FORMATTER_CACHE = MapWrapper
|
||||||
.<String, DateTimeFormatter>wrapHashMap()
|
.<String, DateTimeFormatter>wrap(new SafeConcurrentHashMap<>())
|
||||||
.keyChecker(StringUtils::isNotBlank)
|
.keyChecker(pattern -> Assert.isNotBlank(pattern, "The pattern could not be blank."))
|
||||||
.valueChecker(Objects::nonNull)
|
.valueChecker(formatter -> Assert.notNull(formatter, "The formatter could not be null."))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
public static DateTimeFormatter getDateTimeFormatter(String pattern) {
|
public static DateTimeFormatter getDateTimeFormatter(String pattern) {
|
||||||
if (!DATE_TIME_FORMATTER_CHCHE.containsKey(pattern)) {
|
return DATE_TIME_FORMATTER_CACHE.computeIfAbsent(pattern, DateTimeFormatter::ofPattern);
|
||||||
synchronized (DateTimeUtil.class) {
|
|
||||||
if (!DATE_TIME_FORMATTER_CHCHE.containsKey(pattern)) {
|
|
||||||
DateTimeFormatter formatter = DateTimeFormatter.ofPattern(pattern);
|
|
||||||
DATE_TIME_FORMATTER_CHCHE.put(pattern, formatter);
|
|
||||||
return formatter;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return DATE_TIME_FORMATTER_CHCHE.get(pattern)
|
|
||||||
.orElseThrow(() -> new IllegalStateException("Formatter does not exist."));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String toString(String pattern, ZonedDateTime dateTime) {
|
public static String toString(String pattern, ZonedDateTime dateTime) {
|
||||||
|
@ -124,7 +113,7 @@ public class DateTimeUtil {
|
||||||
* 只是不同时区的表示。
|
* 只是不同时区的表示。
|
||||||
* </p>
|
* </p>
|
||||||
*
|
*
|
||||||
* @param dateTime {@link Date} 对象
|
* @param timeMillis 时间戳
|
||||||
* @param zone 时区
|
* @param zone 时区
|
||||||
* @return 带时区信息的地区时间
|
* @return 带时区信息的地区时间
|
||||||
*/
|
*/
|
||||||
|
@ -189,7 +178,7 @@ public class DateTimeUtil {
|
||||||
/**
|
/**
|
||||||
* 获取时间戳在指定时区的地区时间。
|
* 获取时间戳在指定时区的地区时间。
|
||||||
*
|
*
|
||||||
* @param dateTime {@link Date} 对象
|
* @param timeMillis 时间戳
|
||||||
* @param zone 时区
|
* @param zone 时区
|
||||||
* @return 地区时间
|
* @return 地区时间
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue