2007-07-22 03:47:29 +00:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Hashtable<K, V> implements Map<K, V> {
|
|
|
|
private final HashMap<K, V> map;
|
|
|
|
|
|
|
|
public Hashtable(int capacity) {
|
|
|
|
map = new HashMap(capacity);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Hashtable() {
|
|
|
|
this(0);
|
|
|
|
}
|
|
|
|
|
2007-12-18 18:23:59 +00:00
|
|
|
public Hashtable(Map<? extends K,? extends V> m) {
|
|
|
|
this(m.size());
|
|
|
|
for (Entry<? extends K, ? extends V> entry : m.entrySet()) {
|
|
|
|
put(entry.getKey(), entry.getValue());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-08-22 04:00:46 +00:00
|
|
|
public String toString() {
|
|
|
|
return map.toString();
|
|
|
|
}
|
|
|
|
|
2007-09-26 14:57:34 +00:00
|
|
|
public synchronized boolean isEmpty() {
|
|
|
|
return map.isEmpty();
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public synchronized int size() {
|
|
|
|
return map.size();
|
|
|
|
}
|
|
|
|
|
2007-07-22 19:06:21 +00:00
|
|
|
public synchronized boolean containsKey(K key) {
|
|
|
|
return map.containsKey(key);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized boolean containsValue(V value) {
|
|
|
|
return map.containsValue(value);
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public synchronized V get(K key) {
|
|
|
|
return map.get(key);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized V put(K key, V value) {
|
|
|
|
return map.put(key, value);
|
|
|
|
}
|
|
|
|
|
2007-09-26 14:57:34 +00:00
|
|
|
public synchronized void putAll(Map<? extends K,? extends V> elts) {
|
|
|
|
map.putAll(elts);
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public synchronized V remove(K key) {
|
|
|
|
return map.remove(key);
|
|
|
|
}
|
|
|
|
|
|
|
|
public synchronized void clear() {
|
|
|
|
map.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
public Enumeration<K> keys() {
|
|
|
|
return new Collections.IteratorEnumeration(keySet().iterator());
|
|
|
|
}
|
|
|
|
|
|
|
|
public Enumeration<V> elements() {
|
|
|
|
return new Collections.IteratorEnumeration(values().iterator());
|
|
|
|
}
|
|
|
|
|
|
|
|
public Set<Entry<K, V>> entrySet() {
|
|
|
|
return new Collections.SynchronizedSet(this, map.entrySet());
|
|
|
|
}
|
|
|
|
|
|
|
|
public Set<K> keySet() {
|
|
|
|
return new Collections.SynchronizedSet(this, map.keySet());
|
|
|
|
}
|
|
|
|
|
|
|
|
public Collection<V> values() {
|
|
|
|
return new Collections.SynchronizedCollection(this, map.values());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|