diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotatedElementUtil.java b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotatedElementUtil.java
index 734c00c4c..3b4e9fcd9 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotatedElementUtil.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotatedElementUtil.java
@@ -15,8 +15,8 @@ package org.dromara.hutool.core.annotation;
import org.dromara.hutool.core.annotation.elements.HierarchicalAnnotatedElements;
import org.dromara.hutool.core.annotation.elements.MetaAnnotatedElement;
import org.dromara.hutool.core.annotation.elements.RepeatableMetaAnnotatedElement;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
import org.dromara.hutool.core.array.ArrayUtil;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import org.dromara.hutool.core.util.ObjUtil;
import java.lang.annotation.Annotation;
@@ -133,7 +133,7 @@ import java.util.stream.Stream;
*
缓存
*
为了避免注解以及{@link AnnotatedElement}层级结构解析过程中的大量反射调用,
* 工具类为{@link AnnotatedElement}及其元注解信息进行了缓存。
- * 缓存功能默认基于{@link WeakKeyConcurrentMap}实现,会在gc时自动回收部分缓存数据。
+ * 缓存功能默认基于{@link WeakConcurrentMap}实现,会在gc时自动回收部分缓存数据。
* 但是若有必要,也可以调用{@link #clearCaches()}方法主动清空缓存。
*
* @author huangchengxing
@@ -150,22 +150,22 @@ public class AnnotatedElementUtil {
/**
* 支持属性解析的{@link MetaAnnotatedElement}缓存
*/
- private static final Map> RESOLVED_ELEMENT_CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map> RESOLVED_ELEMENT_CACHE = new WeakConcurrentMap<>();
/**
* 不支持属性解析的{@link MetaAnnotatedElement}缓存
*/
- private static final Map> ELEMENT_CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map> ELEMENT_CACHE = new WeakConcurrentMap<>();
/**
* 不支持属性解析的{@link RepeatableMetaAnnotatedElement}缓存
*/
- private static final Map> RESOLVED_REPEATABLE_ELEMENT_CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map> RESOLVED_REPEATABLE_ELEMENT_CACHE = new WeakConcurrentMap<>();
/**
* 不支持属性解析的{@link RepeatableMetaAnnotatedElement}缓存
*/
- private static final Map> REPEATABLE_ELEMENT_CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map> REPEATABLE_ELEMENT_CACHE = new WeakConcurrentMap<>();
// region ========== find ==========
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotationUtil.java b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotationUtil.java
index 855c10513..7d4c14bde 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotationUtil.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/AnnotationUtil.java
@@ -19,7 +19,7 @@ import org.dromara.hutool.core.exception.HutoolException;
import org.dromara.hutool.core.func.LambdaInfo;
import org.dromara.hutool.core.func.LambdaUtil;
import org.dromara.hutool.core.func.SerFunction;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import org.dromara.hutool.core.reflect.FieldUtil;
import org.dromara.hutool.core.reflect.method.MethodUtil;
import org.dromara.hutool.core.text.CharSequenceUtil;
@@ -50,7 +50,7 @@ public class AnnotationUtil {
/**
* 直接声明的注解缓存
*/
- private static final Map DECLARED_ANNOTATIONS_CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map DECLARED_ANNOTATIONS_CACHE = new WeakConcurrentMap<>();
/**
* 获取直接声明的注解,若已有缓存则从缓存中获取
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/RepeatableAnnotationCollector.java b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/RepeatableAnnotationCollector.java
index fa5f5a7c7..5780c770c 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/annotation/RepeatableAnnotationCollector.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/annotation/RepeatableAnnotationCollector.java
@@ -14,7 +14,7 @@ package org.dromara.hutool.core.annotation;
import org.dromara.hutool.core.array.ArrayUtil;
import org.dromara.hutool.core.collection.CollUtil;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import org.dromara.hutool.core.reflect.method.MethodUtil;
import org.dromara.hutool.core.text.CharSequenceUtil;
@@ -337,7 +337,7 @@ public interface RepeatableAnnotationCollector {
/**
* 可重复注解对应的方法缓存
*/
- private final Map, Object> repeatableMethodCache = new WeakKeyConcurrentMap<>();
+ private final Map, Object> repeatableMethodCache = new WeakConcurrentMap<>();
/**
* 构造
@@ -447,7 +447,7 @@ public interface RepeatableAnnotationCollector {
/**
* 可重复注解对应的方法缓存
*/
- private final Map, Object> repeatableMethodCache = new WeakKeyConcurrentMap<>();
+ private final Map, Object> repeatableMethodCache = new WeakConcurrentMap<>();
/**
* 构造
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanDescCache.java b/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanDescCache.java
index 1563c0f9f..e026d873d 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanDescCache.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanDescCache.java
@@ -13,7 +13,7 @@
package org.dromara.hutool.core.bean;
import org.dromara.hutool.core.func.SerSupplier;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
/**
* Bean属性缓存
@@ -27,7 +27,7 @@ public enum BeanDescCache {
*/
INSTANCE;
- private final WeakKeyConcurrentMap, BeanDesc> bdCache = new WeakKeyConcurrentMap<>();
+ private final WeakConcurrentMap, BeanDesc> bdCache = new WeakConcurrentMap<>();
/**
* 获得属性名和{@link BeanDesc}Map映射
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanInfoCache.java b/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanInfoCache.java
index 005f33e0b..e9e5a398a 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanInfoCache.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/bean/BeanInfoCache.java
@@ -13,8 +13,8 @@
package org.dromara.hutool.core.bean;
import org.dromara.hutool.core.func.SerSupplier;
-import org.dromara.hutool.core.map.reference.ReferenceKeyConcurrentMap;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.ReferenceConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import java.beans.PropertyDescriptor;
import java.util.Map;
@@ -31,8 +31,8 @@ public enum BeanInfoCache {
*/
INSTANCE;
- private final WeakKeyConcurrentMap, Map> pdCache = new WeakKeyConcurrentMap<>();
- private final WeakKeyConcurrentMap, Map> ignoreCasePdCache = new WeakKeyConcurrentMap<>();
+ private final WeakConcurrentMap, Map> pdCache = new WeakConcurrentMap<>();
+ private final WeakConcurrentMap, Map> ignoreCasePdCache = new WeakConcurrentMap<>();
/**
* 获得属性名和{@link PropertyDescriptor}Map映射
@@ -86,10 +86,10 @@ public enum BeanInfoCache {
* 根据是否忽略字段名的大小写,返回不用Cache对象
*
* @param ignoreCase 是否忽略大小写
- * @return {@link ReferenceKeyConcurrentMap}
+ * @return {@link ReferenceConcurrentMap}
* @since 5.4.1
*/
- private ReferenceKeyConcurrentMap, Map> getCache(final boolean ignoreCase) {
+ private ReferenceConcurrentMap, Map> getCache(final boolean ignoreCase) {
return ignoreCase ? ignoreCasePdCache : pdCache;
}
}
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/cache/SimpleCache.java b/hutool-core/src/main/java/org/dromara/hutool/core/cache/SimpleCache.java
index b48134b23..cc41d1b01 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/cache/SimpleCache.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/cache/SimpleCache.java
@@ -18,7 +18,7 @@ import org.dromara.hutool.core.lang.Assert;
import org.dromara.hutool.core.lang.mutable.Mutable;
import org.dromara.hutool.core.lang.mutable.MutableObj;
import org.dromara.hutool.core.map.concurrent.SafeConcurrentHashMap;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import java.io.Serializable;
import java.util.Iterator;
@@ -33,7 +33,7 @@ import java.util.function.Predicate;
import java.util.stream.Collectors;
/**
- * 简单缓存,无超时实现,默认使用{@link WeakKeyConcurrentMap}实现缓存自动清理
+ * 简单缓存,无超时实现,默认使用{@link WeakConcurrentMap}实现缓存自动清理
*
* @param 键类型
* @param 值类型
@@ -57,7 +57,7 @@ public class SimpleCache implements Iterable>, Serializabl
* 构造,默认使用{@link WeakHashMap}实现缓存自动清理
*/
public SimpleCache() {
- this(new WeakKeyConcurrentMap<>());
+ this(new WeakConcurrentMap<>());
}
/**
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/cache/impl/WeakCache.java b/hutool-core/src/main/java/org/dromara/hutool/core/cache/impl/WeakCache.java
index e14a2f337..d8208fac4 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/cache/impl/WeakCache.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/cache/impl/WeakCache.java
@@ -15,9 +15,8 @@ package org.dromara.hutool.core.cache.impl;
import org.dromara.hutool.core.cache.CacheListener;
import org.dromara.hutool.core.lang.Opt;
import org.dromara.hutool.core.lang.mutable.Mutable;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
-
-import java.lang.ref.Reference;
+import org.dromara.hutool.core.lang.ref.Ref;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
/**
* 弱引用缓存
@@ -39,16 +38,18 @@ public class WeakCache extends TimedCache{
* @param timeout 超时时常,单位毫秒,-1或0表示无限制
*/
public WeakCache(final long timeout) {
- super(timeout, new WeakKeyConcurrentMap<>());
+ super(timeout, new WeakConcurrentMap<>());
}
@Override
public WeakCache setListener(final CacheListener listener) {
super.setListener(listener);
- final WeakKeyConcurrentMap, CacheObj> map = (WeakKeyConcurrentMap, CacheObj>) this.cacheMap;
+ final WeakConcurrentMap, CacheObj> map = (WeakConcurrentMap, CacheObj>) this.cacheMap;
// WeakKey回收之后,key对应的值已经是null了,因此此处的key也为null
- map.setPurgeListener((key, value)-> listener.onRemove(Opt.ofNullable(key).map(Reference::get).map(Mutable::get).get(), value.getValue()));
+ map.setPurgeListener((key, value)-> listener.onRemove(
+ Opt.ofNullable(key).map(Ref::get).map(Mutable::get).get(),
+ Opt.ofNullable(value).map(Ref::get).map(CacheObj::getValue).get()));
return this;
}
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/convert/impl/EnumConverter.java b/hutool-core/src/main/java/org/dromara/hutool/core/convert/impl/EnumConverter.java
index c12b55229..7a00d8975 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/convert/impl/EnumConverter.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/convert/impl/EnumConverter.java
@@ -16,10 +16,10 @@ import org.dromara.hutool.core.convert.AbstractConverter;
import org.dromara.hutool.core.convert.ConvertException;
import org.dromara.hutool.core.lang.EnumItem;
import org.dromara.hutool.core.map.MapUtil;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import org.dromara.hutool.core.reflect.ClassUtil;
-import org.dromara.hutool.core.reflect.method.MethodUtil;
import org.dromara.hutool.core.reflect.ModifierUtil;
+import org.dromara.hutool.core.reflect.method.MethodUtil;
import org.dromara.hutool.core.util.EnumUtil;
import java.lang.reflect.Method;
@@ -42,7 +42,7 @@ public class EnumConverter extends AbstractConverter {
*/
public static final EnumConverter INSTANCE = new EnumConverter();
- private static final WeakKeyConcurrentMap, Map, Method>> VALUE_OF_METHOD_CACHE = new WeakKeyConcurrentMap<>();
+ private static final WeakConcurrentMap, Map, Method>> VALUE_OF_METHOD_CACHE = new WeakConcurrentMap<>();
@Override
protected Object convertInternal(final Class> targetClass, final Object value) {
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaFactory.java b/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaFactory.java
index 4daa2d95d..0b3fb4120 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaFactory.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaFactory.java
@@ -15,8 +15,9 @@ package org.dromara.hutool.core.func;
import org.dromara.hutool.core.exception.HutoolException;
import org.dromara.hutool.core.lang.Assert;
import org.dromara.hutool.core.lang.mutable.MutableEntry;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
-import org.dromara.hutool.core.reflect.*;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
+import org.dromara.hutool.core.reflect.ClassUtil;
+import org.dromara.hutool.core.reflect.ReflectUtil;
import org.dromara.hutool.core.reflect.lookup.LookupUtil;
import org.dromara.hutool.core.reflect.method.MethodTypeUtil;
import org.dromara.hutool.core.reflect.method.MethodUtil;
@@ -37,7 +38,7 @@ public class LambdaFactory {
throw new IllegalAccessException();
}
- private static final Map, Executable>, Object> CACHE = new WeakKeyConcurrentMap<>();
+ private static final Map, Executable>, Object> CACHE = new WeakConcurrentMap<>();
/**
* 构建Lambda
diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaUtil.java b/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaUtil.java
index ead7b6429..3f0941350 100644
--- a/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaUtil.java
+++ b/hutool-core/src/main/java/org/dromara/hutool/core/func/LambdaUtil.java
@@ -17,10 +17,10 @@ import org.dromara.hutool.core.classloader.ClassLoaderUtil;
import org.dromara.hutool.core.exception.HutoolException;
import org.dromara.hutool.core.lang.Assert;
import org.dromara.hutool.core.lang.Opt;
-import org.dromara.hutool.core.map.reference.WeakKeyConcurrentMap;
+import org.dromara.hutool.core.map.reference.WeakConcurrentMap;
import org.dromara.hutool.core.reflect.ClassDescUtil;
-import org.dromara.hutool.core.reflect.method.MethodUtil;
import org.dromara.hutool.core.reflect.ModifierUtil;
+import org.dromara.hutool.core.reflect.method.MethodUtil;
import java.io.Serializable;
import java.lang.invoke.SerializedLambda;
@@ -37,7 +37,7 @@ import java.util.function.*;
*/
public class LambdaUtil {
- private static final WeakKeyConcurrentMap