至于为什么会引起死循环,大概是因为HashMap的Entry链表会形成链式的结构,一旦形成了Entry的链式结构,链表中的next指针就会一直不为空,这样就会导致死循环
不使用HashTable的原因?...所使用的锁分段技术
将数据一段一段的存储,然后为每一段都配一把锁,当一个线程只是占用其中的一个数据段时,其他段的数据也能被其他线程访问
2,currentHashMap的结构
currentHashMap...currentHashMap的体系结构
?...,这样做会使得Hash的过程比普通的HashMap要长
写操作的时候可以只对元素所在的Segment进行加锁即可,不会影响到其他的Segment,这样,在最理想的情况下,ConcurrentHashMap...乐观锁是通过某种方式不加锁,比如说添加version字段来获取数据
CAS操作包含三个操作数-----内存位置,预期的原值,和新值.如果内存的值和预期的原值是一致的,那么就转化为新值.CAS是通过不断的循环来获取新值的