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

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