码迷,mamicode.com
首页 > 其他好文 > 详细

CopyOnWriteArrayList源码add加锁的意义

时间:2019-07-06 17:39:41      阅读:80      评论:0      收藏:0      [点我收藏+]

标签:数组   public   div   unlock   操作   网上   lock   nts   最新   

源码

/**
* 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的文章大多拷贝自http://ifeve.com/java-copy-on-write/ ,原文对这个疑问的解释如下:

技术图片

 

我的理解

这里我觉得这原文的解释不太合理,我的思考是:add的流程“是复制当前数组获得新数组 -> 将元素放到新数组末尾 -》更新数组引用,将其指向新的内存”,如果没有加锁,那么多个线程并发add的时候拿的容器数组不一定是最新的,导致的结果是有些线程add的结果被紧随其后的线程add操作覆盖掉,如下图

技术图片

 

CopyOnWriteArrayList源码add加锁的意义

标签:数组   public   div   unlock   操作   网上   lock   nts   最新   

原文地址:https://www.cnblogs.com/ming-szu/p/11143255.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!