线程-并发容器
前言
主要对比较常见的并发容器,进行了学习。已经在一些场景中所遇到的坑,进行解决。
提示:以下是本篇文章正文内容
一、HashMap容器
HashMap不是一个线程安全的容器,在1.8版本之前,并发环境中有可能会造成死循环,以及导致数据丢失。
二、ConcurrentHashMap容器
ConcurrentHashMap与HashMap的区别它是线程安全的,在1.8版本之后它采用了数组+链表+红黑树,以及使用Node+Cas+Syn来保证并发安全。
三、CopyOnWriteArrayList容器
CopyOnWriteArrayList字面的意思就是新建一个数组,再拷贝一份写入,造成开销较大。但是它也有它的好处,就是在读取数据的时候不会锁住list。
四、生产问题
在细节上,我们要注意一些问题,去理解这个并发容器的含义与使用方式,不然有点时候适得其反。
思考
为什么超过8个才转红黑树?
其实很多时候并发容器HashMap,并不会转成红黑树,转成红黑树的时候,就要开始怀疑自己的代码有问题了。