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

io.vertx.sqlclient.impl.cache.LruCache Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (c) 2011-2020 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */

package io.vertx.sqlclient.impl.cache;

import java.util.*;

/**
 * An LRU replacement strategy cache based on {@link java.util.LinkedHashMap} for prepared statements.
 */
public class LruCache extends LinkedHashMap {

  List removed;
  private final int capacity;

  public LruCache(int capacity) {
    super(capacity, 0.75f, true);
    this.capacity = capacity;
  }

  /**
   * Evict the eldest entry from the cache
   *
   * @return the eldest value or {@code null}
   */
  public V evict() {
    Iterator it = values().iterator();
    if (it.hasNext()) {
      V value = it.next();
      it.remove();
      return value;
    } else {
      return null;
    }
  }

  public List cache(K key, V value) {
    put(key, value);
    if (removed != null) {
      List evicted = removed;
      removed = null;
      return evicted;
    } else {
      return Collections.emptyList();
    }
  }

  @Override
  protected boolean removeEldestEntry(Map.Entry eldest) {
    boolean evict = size() > capacity;
    if (evict) {
      if (removed == null) {
        removed = new ArrayList<>();
      }
      removed.add(eldest.getValue());
      return true;
    } else {
      return false;
    }
  }

  @Override
  public void clear() {
    super.clear();
    removed = null;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy