blob: 866794fdcd63a4b0b36a1e9821eddec969b46e5c [file] [log] [blame]
alshabib1f44e8e2014-08-14 15:19:57 -07001/**
2 * Copyright 2011, Big Switch Networks, Inc.
3 * Originally created by David Erickson, Stanford University
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License"); you may
6 * not use this file except in compliance with the License. You may obtain
7 * a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14 * License for the specific language governing permissions and limitations
15 * under the License.
16 **/
17
tom9ccd7812014-08-25 22:43:19 -070018package org.onlab.onos.of.controller.impl.util;
alshabib1f44e8e2014-08-14 15:19:57 -070019
20import java.util.LinkedHashMap;
21import java.util.Map;
22
23public class LRUHashMap<K, V> extends LinkedHashMap<K, V> {
24
25 private static final long serialVersionUID = 1L;
26
27 private final int capacity;
28
29 public LRUHashMap(int capacity) {
30 super(capacity + 1, 0.75f, true);
31 this.capacity = capacity;
32 }
33
34 protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
35 return size() > capacity;
36 }
37
38}