集合类不安全之list,set与map
ArrayList 线程不安全,为什么不安全呢?看下面截图
看add源码,为了保证并发性和效率,add方法没有加锁(synchronized)
为了解决arrayList线程不安全这个问题,我们有以下三种解决方法:
1.继承vector方法(vector的add方法有锁)
2.collections是collection集合类的工具类(利用工具类来找个线程安全的辅助类继承),我们可以看到collections里面还有相似的synchronizedMap和synchronizedSet类,推理map和set也是线程不安全集合。 Collections.synchronizedList(new ArrayList<>())是把一个线程不安全的集合封装成一个安全的集合
3.限制不可以使用vector和Collections工具类的解决办法
newCopyOnWriteArrayList()
参照上面的list解决线程不安全的方法,set是有两种解决方法
1.Collections.synchronizedSet(new HashSet<>());
2.new CopyOnWriteArraySet<>();
HashSet的底层值就是HashMap
但是为什么HashSet的add方法传参一个值,而hashMap的put方法传参两个值?
因为:HashSet的add方法调用的HashMap的put方法时,第二个值是个恒定的值,为PRESENT