출처: http://apurvagnihotri.blogspot.kr/2010/06/hashmap-vs-hashtable.html
HashMap and HashTable both provide key-value access to data.
The Hashtable is among the original collection classes in Java.Hashtable extends the Dictionary class, which as the Javadocs state, is obsolete and has been replaced by the Map interface. HashMap is part of the new Collections Framework, added with Java 2.
The key difference between the two is that access to the Hashtable is synchronized on the table while access to the HashMap is not synchronized.This makes HashMap better for non-threaded applications, as unsynchronized Objects typically perform better than synchronized ones
HashMap has a more complex hashing algorithm then Hashtable. It takes the hash value from the key and then hashes it again (double hashing). This can improve the distribution of the keys and hence the performance of the Map.
Another difference is that iterator in the HashMap is fail-safe while the enumerator for the Hashtable isn't. If we change the map while iterating, it will throw exception.
Third difference is that HashMap permits null values in it, while Hashtable doesn't.Also note that only one NULL value is allowed as a key in HashMap. HashMap does not allow multiple keys to be NULL. Nevertheless, it can have multiple NULL values.
Using ConcurrentHashmap: for having a thread safe map we can use ConcurrenthashMap(from java5 onwards) as well instead of Hashtable which has become obsolete.
private Map myConcMap = new ConcurrentHashMap();
Now The question arises why ConcurrentHashMap and not HashTable or just have a synchronised access to HasMap.
So the major advantage of using ConcurrentHashMap is "performance" as the lock is not applied on wholeMap as is the case with a Synchronised access to hashmap or Hashtable.
As we know that hash maps store their data in a series of separate buckets, it is possible to lock only the portion of the map that is being accessed.ConcurrentHashMap uses this to provide us a highly optimized synchronised way of accessing HashMap.ConcurrentHash hash map follows following to provide a concurrent access:
1. Writing to a ConcurrentHashMap locks only a portion of the map
2. Reads can occur without locking.
Some disadvantges of ConcurrentHashMap:
ConcurrentHashMap will generally take up more memory.
it cannot take null as a key.
'Archive' 카테고리의 다른 글
Java transient 키워드에 대해 몰랐던 사실 (0) | 2012.08.26 |
---|---|
HashSet vs TreeSet (0) | 2012.08.23 |
상수를 public static final로 정의해서 사용해야 할까? private static final로 정의해서 getter를 사용해야 할까? (0) | 2012.08.23 |
Private constructor를 쓰는 5가지 경우 (0) | 2012.08.23 |
객체지향 설계의 5원칙: OCP, SRP, LSP, DIP, ISP (0) | 2012.07.29 |