org.amino.ds.lockfree
Class LockFreeDictionary<K,V>

java.lang.Object
  extended by org.amino.ds.lockfree.LockFreeDictionary<K,V>
Type Parameters:
K - type of key in the dictionary
V - type of value in the dictionary
All Implemented Interfaces:
java.util.Map<K,V>

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

This is a thread-safe and lock-free dictionary. This lock free concurrent dictionary implementation is based on the algorithm defined in the follwoing paper: Scalable and Lock-Free Concurrent Dictionaries By Hakan Sundell and Philippas Tsigas

Author:
raja

Nested Class Summary
 
Nested classes/interfaces inherited from interface java.util.Map
java.util.Map.Entry<K,V>
 
Constructor Summary
LockFreeDictionary()
          default constructor.
LockFreeDictionary(java.util.Comparator<? super K> cmp)
           
 
Method Summary
 void clear()
          
 boolean containsKey(java.lang.Object key)
          
 boolean containsValue(java.lang.Object value)
          
 K deleteValue(V d)
           
 java.util.Set<java.util.Map.Entry<K,V>> entrySet()
          
 V get(java.lang.Object key)
          
 boolean isEmpty()
          
 java.util.Set<K> keySet()
          
 V put(K key, V value)
          
 void putAll(java.util.Map<? extends K,? extends V> m)
          
 V remove(java.lang.Object key)
          
 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

LockFreeDictionary

public LockFreeDictionary()
default constructor.


LockFreeDictionary

public LockFreeDictionary(java.util.Comparator<? super K> cmp)
Parameters:
cmp - customized comparator
Method Detail

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>

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>

isEmpty

public boolean isEmpty()

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

deleteValue

public K deleteValue(V d)
Parameters:
d - value
Returns:
key with value d


Copyright © 2008. All Rights Reserved.