Jdk8 Hashmap ConcurrentHashMap
JDK1.8 Hashmap
JDK1.8 ConcurrentHashMap
- 不采用segment而采用 synchronized (f) f = table[i]; 减小锁的力度
- 设计了MOVED状态 当resize的中过程中 线程2还在put数据,线程2会帮助resize。
- 使用3个CAS操作来确保node的一些操作的原子性,这种方式代替了锁。
- sizeCtl的不同值来代表不同含义,起到了控制的作用。
参考 http://www.importnew.com/28263.html 和 JDK1.8 HashMap, ConcurrentHashMap 源代码