blob: 7b8d536cc74f14824ba4f6596fe2a52ffda8ebad [file] [log] [blame]
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -08001/**
Ray Milkey269ffb92014-04-03 14:43:30 -07002 * 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 **/
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -080017
18package net.floodlightcontroller.util;
19
20import java.util.LinkedHashMap;
21import java.util.Map;
22
23public class LRUHashMap<K, V> extends LinkedHashMap<K, V> {
Ray Milkey269ffb92014-04-03 14:43:30 -070024
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -080025 private static final long serialVersionUID = 1L;
Ray Milkey269ffb92014-04-03 14:43:30 -070026
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -080027 private final int capacity;
Ray Milkey269ffb92014-04-03 14:43:30 -070028
29 public LRUHashMap(int capacity) {
30 super(capacity + 1, 0.75f, true);
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -080031 this.capacity = capacity;
32 }
Ray Milkey269ffb92014-04-03 14:43:30 -070033
34 protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
35 return size() > capacity;
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -080036 }
37
38}