博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CopyOnWriteArrayList源码add加锁的意义
阅读量:5111 次
发布时间:2019-06-13

本文共 802 字,大约阅读时间需要 2 分钟。

源码

/*** Appends the specified element to the end of this list.** @param e element to be appended to this list* @return {
@code true} (as specified by {
@link Collection#add})*/public boolean add(E e) { final ReentrantLock lock = this.lock; lock.lock(); try { Object[] elements = getArray(); int len = elements.length; Object[] newElements = Arrays.copyOf(elements, len + 1); newElements[len] = e; setArray(newElements); return true; } finally { lock.unlock(); }}

 

网上看到的解释

网上关于CopyOnWriteArrayList的文章大多拷贝自 ,原文对这个疑问的解释如下:

 

我的理解

这里我觉得这原文的解释不太清晰或不太合理,我的思考是:

add的流程“是复制当前数组获得新数组 -> 将元素放到新数组末尾 -》更新数组引用,将其指向新的内存”

如果没有加锁,那么多个线程并发add的时候拿的容器数组不一定是最新的,导致的结果是有些线程add的结果被紧随其后的线程add操作覆盖掉,如下图

 

转载于:https://www.cnblogs.com/ming-szu/p/11143255.html

你可能感兴趣的文章
【转】Appium_API(翻译+用法说明)
查看>>
P2219 [HAOI2007]修筑绿化带
查看>>
charles 在mac下 抓取 https包
查看>>
WebRequest之Post写法
查看>>
转载 根据身份证号得到性别跟出生日期
查看>>
C#MVC Razor的Ajax.BeginForm里面的OnSuccess未执行(未成功跳转)
查看>>
codevs 1060
查看>>
一句道破所有的springmvc
查看>>
音频编码标准
查看>>
Leetcode 345 Reverse Vowels in a String
查看>>
计算机
查看>>
初识网络编程
查看>>
并发编程之线程(代码)
查看>>
典型用户和场景分析
查看>>
linux中将video转换成gif
查看>>
【转】Linux 下取进程占用 cpu/内存 最高的前10个进程
查看>>
Python之list、tuple、dict、set
查看>>
IOS开发系列—Objective-C之Foundation框架
查看>>
专业实训题目需求分析
查看>>
第二天习题
查看>>