From b086f57f56bf0eb9dab9cf321a0f69aaaae84347 Mon Sep 17 00:00:00 2001 From: Andrew Branson Date: Wed, 30 May 2012 08:37:45 +0200 Subject: Initial Maven Conversion --- .../java/com/c2kernel/utils/TransientCache.java | 130 +++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 src/main/java/com/c2kernel/utils/TransientCache.java (limited to 'src/main/java/com/c2kernel/utils/TransientCache.java') diff --git a/src/main/java/com/c2kernel/utils/TransientCache.java b/src/main/java/com/c2kernel/utils/TransientCache.java new file mode 100644 index 0000000..d58617e --- /dev/null +++ b/src/main/java/com/c2kernel/utils/TransientCache.java @@ -0,0 +1,130 @@ + +package com.c2kernel.utils; +import java.lang.ref.Reference; +import java.util.AbstractMap; +import java.util.AbstractSet; +import java.util.Hashtable; +import java.util.Iterator; +import java.util.Map; +import java.util.Set; +/************************************************************************** + * TransientCache - Uses transient references to allow unused entries to be + * reaped by the java garbage collector. + * + * $Revision: 1.1 $ + * $Date: 2004/04/20 09:37:02 $ + * + * Copyright (C) 2003 CERN - European Organization for Nuclear Research + * All rights reserved. + **************************************************************************/ +public abstract class TransientCache extends AbstractMap { + + private Map> map = new Hashtable>(); + + @Override + public synchronized Set> entrySet() { + Map newMap = new Hashtable(); + Iterator>> iter = map.entrySet().iterator(); + while (iter.hasNext()) { + Entry> me = iter.next(); + Reference ref = me.getValue(); + V o = ref.get(); + if (o == null) { + // Delete cleared reference + iter.remove(); + } else { + // Copy out interior object + newMap.put(me.getKey(), o); + } + } + // Return set of interior objects + return newMap.entrySet(); + } + + @Override + public synchronized V put(K key, V value) { + Reference ref = makeReference(value); + ref = map.put(key, ref); + if (ref != null) + return (ref.get()); + return null; + } + + public abstract Reference makeReference(Object value); + + @Override + public V remove(Object key) { + Iterator>> i = map.entrySet().iterator(); + Entry> correctEntry = null; + if (key == null) { + while (correctEntry == null && i.hasNext()) { + Entry> e = i.next(); + if (e.getKey() == null) + correctEntry = e; + } + } else { + while (correctEntry == null && i.hasNext()) { + Entry> e = i.next(); + if (key.equals(e.getKey())) + correctEntry = e; + } + } + V oldValue = null; + if (correctEntry != null) { + Reference correctReference = correctEntry.getValue(); + oldValue = correctReference.get(); + i.remove(); + } + return oldValue; + } + /** + * + */ + @Override + public void clear() { + map.entrySet().clear(); + } + + private transient Set keySet = null; + + @Override + public Set keySet() { + if (keySet == null) { + keySet = new AbstractSet() { + @Override + public Iterator iterator() { + return new Iterator() { + private Iterator>> i = map.entrySet().iterator(); + + @Override + public boolean hasNext() { + return i.hasNext(); + } + + @Override + public K next() { + return i.next().getKey(); + } + + @Override + public void remove() { + i.remove(); + } + }; + } + + @Override + public int size() { + return TransientCache.this.size(); + } + + @Override + public boolean contains(Object k) { + return TransientCache.this.containsKey(k); + } + }; + } + return keySet; + } + +} -- cgit v1.2.3