All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.saxon.sort.LRUCache Maven / Gradle / Ivy

package net.sf.saxon.sort;

import java.util.LinkedHashMap;
import java.util.Map;

/**
 * An LRU cache, based on LinkedHashMap.
 * Synthesized and simplified from various published examples of the genre.
 * The methods are not synchronized.
 */
public class LRUCache {

    private LinkedHashMap map;

    /**
     * Creates a new LRU cache.
     *
     * @param cacheSize the maximum number of entries that will be kept in this cache.
     */
    public LRUCache(final int cacheSize) {
        map = new LinkedHashMap(cacheSize, 0.75f, true) {
            protected boolean removeEldestEntry(Map.Entry eldest) {
                return cacheSize < size();
            }
        };
    }

    /**
     * Retrieves an entry from the cache.
* The retrieved entry becomes the most recently used entry. * * @param key the key whose associated value is to be returned. * @return the value associated to this key, or null if no value with this key exists in the cache. */ public Object get(Object key) { return map.get(key); } /** * Adds an entry to this cache. * If the cache is full, the LRU (least recently used) entry is dropped. * * @param key the key with which the specified value is to be associated. * @param value a value to be associated with the specified key. */ public void put(Object key, Object value) { map.put(key, value); } /** * Clear the cache */ public void clear() { map.clear(); } } // // The contents of this file are subject to the Mozilla Public License Version 1.0 (the "License"); // you may not use this file except in compliance with the License. You may obtain a copy of the // License at http://www.mozilla.org/MPL/ // // Software distributed under the License is distributed on an "AS IS" basis, // WITHOUT WARRANTY OF ANY KIND, either express or implied. // See the License for the specific language governing rights and limitations under the License. // // The Original Code is: all this file // // The Initial Developer of the Original Code is Michael H. Kay. // // Contributor(s): //




© 2015 - 2025 Weber Informatics LLC | Privacy Policy