1.ConcurrentHashMap与HashMap有什么区别?
- 数据结构:HashMap的数据结构在HashMap那一篇已经有了很详细的说明,这里就不赘述了,没有看过的小伙伴可以点击这里每日一面系列之HashMap夺命连环问。在JDK1.7中ConcurrentHashMap底层采用分段数组+链表的方式实现。在JDK1.8中ConcurrentHashMap与JDK1.8中的HashMap底层数据结构一样,都是采用数组+链表或者数组+红黑树的方式实现。这二者底层数据结构都是以数组为主体的。
- 线程安全:HashMap是线程不安全的,ConcurrentHashMap是线程安全的。
2.说一下ConcurrentHashMap的工作原理,put()和get()的工作流程是怎样的?
存储对象时,将key和vaule传给put()方法:
- 如果没有初始化,就调用initTable()方法对数组进行初始化;
- 如果没有hash冲突则直接通过CAS进行无锁插入;
- 如果需要扩容,就先进行扩容,扩容为原来的两倍;
- 如果存在hash冲突,就通过加锁的方式进行插入,从而保证线程安全。(如果是链表就按照尾插法插入,如果是红黑树就按照红黑树的数据结构进行插入);