HashMap ConcurrentHashMap HashTable synchronizedMap
1.HashMap与HashTable:
HashMap 非线程安全,支持null key 和null 值。 而HashTable线程安全,不支持null key和null 值。 HashMap 可以很容易转换到LinkedHashMap(支持插入有序,设置,访问,删除有序,而TreeMap支持对Key有序,TreeMap实则为红黑树), 而HashTable不能。
2.ConcurrentHashMap:
在并发环境下,ConcurrentHashMap弱化了size(), isEmpty()函数的语义,加强了get, put, containsKey, remove等操作的性能。即size, isEmpty返回的值可能已经过期,它实际上只是一个估计值,并不是一个精确值。虽然看上去这很不靠谱,但在并发环境下,这两个方法的用处很小,因为他们的返回值总在不断变化。
使用ConcurrentHashMap的话,不要通过synchronize该对象来创建新的原子操作。因为ConcurrentHashMap的加锁粒度要小很多,并非是锁整个对象,你把整个对象锁住了,辛辛苦苦写细粒度锁的author会打死你的,想通过简单的锁整个对象来创建新的原子操作,可以了解一下Collections.synchronizedMap()。