八.线程同步容器-CopyOnWriteArrayList

一.CopyOnWrite容器

CopyOnWrite容器即写时复制的容器。通俗的理解是当我们往一个容器添加元素的时候,不直接往当前容器添加,而是先将当前容器进行Copy,复制出一个新的容器,然后新的容器里添加元素,添加完元素之后,再将原容器的引用指向新的容器。这样做的好处是我们可以对CopyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素。所以CopyOnWrite容器也是一种读写分离的思想,读和写不同的容器。

二.结构

*与普通list大致相同,底层都是数字

image.png

三.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();
        }
    }

四.优劣点

  • CopyOnWrite并发容器用于读多写少的并发场景。
  • 我们可以对CopyOnWrite容器进行并发的读,而不需要加锁
  • CopyOnWrite容器只能保证数据的最终一致性,所以如果你希望,马上能读到写入的的数据,请不要使用CopyOnWrite容器。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容