TUM CCSM Commons

edu.tum.cs.commons.collections
Class HybridMapBase<K,V>

java.lang.Object
  extended by edu.tum.cs.commons.collections.HybridMapBase<K,V>
All Implemented Interfaces:
java.util.Map<K,V>
Direct Known Subclasses:
MemoryEfficientStringMap

public abstract class HybridMapBase<K,V>
extends java.lang.Object
implements java.util.Map<K,V>

A hybrid map is a map which starts with one map implementation, but switches to another one after a certain size is reached.

Version:
$Rev: 29399 $
Author:
hummelb, $Author: juergens $
Rating:
GREEN Hash: 8464B0259DB7F1270D62FF135895F9FC

Nested Class Summary
 
Nested classes/interfaces inherited from interface java.util.Map
java.util.Map.Entry<K,V>
 
Constructor Summary
protected HybridMapBase(java.util.Map<K,V> initialMap)
          Constructor.
 
Method Summary
 void clear()
          
 boolean containsKey(java.lang.Object key)
          
 boolean containsValue(java.lang.Object value)
          
 java.util.Set<java.util.Map.Entry<K,V>> entrySet()
          
 V get(java.lang.Object key)
          
 boolean isEmpty()
          
 java.util.Set<K> keySet()
          
protected abstract  java.util.Map<K,V> obtainNewMap()
          Template method for obtaining a new map implementation after shouldSwitch(Map) returned true.
 V put(K key, V value)
          
 void putAll(java.util.Map<? extends K,? extends V> m)
          
 V remove(java.lang.Object key)
          
protected abstract  boolean shouldSwitch(java.util.Map<K,V> map)
          Template method for deciding that a switch of map implementation should be performed before the next insertion.
 int size()
          
 java.util.Collection<V> values()
          
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface java.util.Map
equals, hashCode
 

Constructor Detail

HybridMapBase

protected HybridMapBase(java.util.Map<K,V> initialMap)
Constructor.

Method Detail

shouldSwitch

protected abstract boolean shouldSwitch(java.util.Map<K,V> map)
Template method for deciding that a switch of map implementation should be performed before the next insertion. This will be called right before each put operation. If this returns true, the new map implementation is obtained via obtainNewMap() and all values are copied.

Parameters:
map - the currently used map.

obtainNewMap

protected abstract java.util.Map<K,V> obtainNewMap()
Template method for obtaining a new map implementation after shouldSwitch(Map) returned true.


clear

public void clear()

Specified by:
clear in interface java.util.Map<K,V>

containsKey

public boolean containsKey(java.lang.Object key)

Specified by:
containsKey in interface java.util.Map<K,V>

containsValue

public boolean containsValue(java.lang.Object value)

Specified by:
containsValue in interface java.util.Map<K,V>

entrySet

public java.util.Set<java.util.Map.Entry<K,V>> entrySet()

Specified by:
entrySet in interface java.util.Map<K,V>

get

public V get(java.lang.Object key)

Specified by:
get in interface java.util.Map<K,V>

isEmpty

public boolean isEmpty()

Specified by:
isEmpty in interface java.util.Map<K,V>

keySet

public java.util.Set<K> keySet()

Specified by:
keySet in interface java.util.Map<K,V>

put

public V put(K key,
             V value)

Specified by:
put in interface java.util.Map<K,V>

putAll

public void putAll(java.util.Map<? extends K,? extends V> m)

Specified by:
putAll in interface java.util.Map<K,V>

remove

public V remove(java.lang.Object key)

Specified by:
remove in interface java.util.Map<K,V>

size

public int size()

Specified by:
size in interface java.util.Map<K,V>

values

public java.util.Collection<V> values()

Specified by:
values in interface java.util.Map<K,V>

TUM CCSM Commons

TUM CCSM Commons - 2.7