diff --git a/jetcache-core/src/main/java/com/alicp/jetcache/embedded/Cleaner.java b/jetcache-core/src/main/java/com/alicp/jetcache/embedded/Cleaner.java index 4586bbbc..56d2a2e1 100644 --- a/jetcache-core/src/main/java/com/alicp/jetcache/embedded/Cleaner.java +++ b/jetcache-core/src/main/java/com/alicp/jetcache/embedded/Cleaner.java @@ -4,10 +4,9 @@ import java.lang.ref.WeakReference; import java.util.Iterator; -import java.util.LinkedList; +import java.util.concurrent.ConcurrentLinkedQueue; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; -import java.util.concurrent.locks.ReentrantLock; /** * Created on 2017/2/28. @@ -16,8 +15,7 @@ */ class Cleaner { - static LinkedList> linkedHashMapCaches = new LinkedList<>(); - private static final ReentrantLock reentrantLock = new ReentrantLock(); + static ConcurrentLinkedQueue> linkedHashMapCaches = new ConcurrentLinkedQueue<>(); static { ScheduledExecutorService executorService = JetCacheExecutor.defaultExecutor(); @@ -25,29 +23,19 @@ class Cleaner { } static void add(LinkedHashMapCache cache) { - reentrantLock.lock(); - try{ - linkedHashMapCaches.add(new WeakReference<>(cache)); - }finally { - reentrantLock.unlock(); - } + linkedHashMapCaches.add(new WeakReference<>(cache)); } static void run() { - reentrantLock.lock(); - try{ - Iterator> it = linkedHashMapCaches.iterator(); - while (it.hasNext()) { - WeakReference ref = it.next(); - LinkedHashMapCache c = ref.get(); - if (c == null) { - it.remove(); - } else { - c.cleanExpiredEntry(); - } + Iterator> it = linkedHashMapCaches.iterator(); + while (it.hasNext()) { + WeakReference ref = it.next(); + LinkedHashMapCache c = ref.get(); + if (c == null) { + it.remove(); + } else { + c.cleanExpiredEntry(); } - }finally { - reentrantLock.unlock(); } } diff --git a/jetcache-core/src/main/java/com/alicp/jetcache/embedded/LinkedHashMapCache.java b/jetcache-core/src/main/java/com/alicp/jetcache/embedded/LinkedHashMapCache.java index 9436fbb8..ee2fbe8f 100644 --- a/jetcache-core/src/main/java/com/alicp/jetcache/embedded/LinkedHashMapCache.java +++ b/jetcache-core/src/main/java/com/alicp/jetcache/embedded/LinkedHashMapCache.java @@ -65,25 +65,30 @@ protected boolean removeEldestEntry(Map.Entry eldest) { void cleanExpiredEntry() { Lock lock = readWriteLock.writeLock(); lock.lock(); - try{ - for (Iterator it = entrySet().iterator(); it.hasNext();) { + long t = System.currentTimeMillis(); + try { + for (Iterator it = entrySet().iterator(); it.hasNext(); ) { Map.Entry en = (Map.Entry) it.next(); Object value = en.getValue(); - if (value != null && value instanceof CacheValueHolder) { - CacheValueHolder h = (CacheValueHolder) value; - if (System.currentTimeMillis() >= h.getExpireTime()) { + if (value != null) { + CacheValueHolder h; + try { + h = (CacheValueHolder) value; + } catch (ClassCastException e) { + // assert false + logger.error("value of key " + en.getKey() + " is not a CacheValueHolder. type=" + value.getClass()); + it.remove(); + continue; + } + if (t >= h.getExpireTime()) { it.remove(); } } else { // assert false - if (value == null) { - logger.error("key " + en.getKey() + " is null"); - } else { - logger.error("value of key " + en.getKey() + " is not a CacheValueHolder. type=" + value.getClass()); - } + logger.error("key " + en.getKey() + " is null"); } } - }finally { + } finally { lock.unlock(); } }