com.abubusoft.kripton.android.sqlite.commons.LRUCache Maven / Gradle / Ivy
/*******************************************************************************
* Copyright 2018 Francesco Benincasa ([email protected])
*
* Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
******************************************************************************/
package com.abubusoft.kripton.android.sqlite.commons;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentLinkedQueue;
// TODO: Auto-generated Javadoc
/**
* http://badalb.blogspot.it/2016/09/implement-lru-cache-in-java.html
*
* @author Francesco Benincasa ([email protected])
* @param the key type
* @param the value type
*/
public class LRUCache {
/**
* The listener interface for receiving onRemove events.
* The class that is interested in processing a onRemove
* event implements this interface, and the object created
* with that class is registered with a component using the
* component's addOnRemoveListener
method. When
* the onRemove event occurs, that object's appropriate
* method is invoked.
*
* @param the value type
*/
public interface OnRemoveListener {
/**
* On remove.
*
* @param value the value
*/
void onRemove(V value);
}
/** The max size. */
private final int maxSize;
/** The map. */
private ConcurrentHashMap map;
/** The queue. */
private ConcurrentLinkedQueue queue;
/** The listener. */
private OnRemoveListener listener;
/**
* Instantiates a new LRU cache.
*
* @param maxSize the max size
* @param listener the listener
*/
public LRUCache(final int maxSize, OnRemoveListener listener) {
this.maxSize = maxSize;
this.listener = listener;
map = new ConcurrentHashMap(maxSize);
queue = new ConcurrentLinkedQueue();
}
/**
* Put.
*
* @param key the key
* @param value the value
*/
public void put(final K key, final V value) {
if (map.containsKey(key)) {
// remove the key from the FIFO queue
queue.remove(key);
}
while (queue.size() >= maxSize) {
K oldestKey = queue.poll();
if (null != oldestKey) {
if (listener != null) {
listener.onRemove(map.remove(oldestKey));
} else {
map.remove(oldestKey);
}
}
}
queue.add(key);
map.put(key, value);
}
/**
* Gets the.
*
* @param key the key
* @return the v
*/
public V get(final K key) {
if (map.containsKey(key)) {
// remove from queue and add it again in FIFO queue
queue.remove(key);
queue.add(key);
}
return map.get(key);
}
/**
* Clear.
*/
public void clear() {
queue.clear();
if (listener != null) {
for (V item : map.values()) {
listener.onRemove(item);
}
}
map.clear();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy