Java(Android)数据结构汇总(一)-- List(下)

传送门:Java(Android)数据结构汇总 -- 总纲

简介

List接口在java.util.concurrent包下只有CopyOnWriteArrayList一个实现类,它是一个线程安全的数据结构。

实现

CopyOnWrite(写时拷贝)是为了并发而实现的一种懒惰策略。通常我们为了实现并发都是使用锁来实现的,比如使用synchronized关键之等。但是锁会带来性能上的开销。为了提高性能,CopyOnWrite采用的是一种读写分离的思想,其原理如下:

当需要修改目标数据时,先将目标数据复制一份,并在这份复制的数据上进行修改(此时如果有其他线程来读取数据则正常的从原数据上读取),修改完成后再将数据的引用指向这份复制出来并修改后的数据。这样就在不用锁的条件下实现了对数据的并发读写。

CopyOnWrite的特点就是:在同一时刻,可以有多个线程进行读操作,但是只能有一个线程进行写操作

如果明白了CopyOnWrite机制,那么CopyOnWriteArrayList就很简单了。

我们先来看下读操作源码:

public E get(int index) {
    return get(getArray(), index);
}

final Object[] getArray() {
    // 获取当前数组
    return elements;
}

private E get(Object[] a, int index) {
    // 从给定的数组中取index位置的元素
    return (E) a[index];
}

读操作的源码很简单,没有任何加锁机制。

我们再来看看写操作源码:

public boolean add(E e) {
   // 因为写操作只能同时有一个线程进行,所以这里加了锁
   // 这里用的是一个Object(lock)对象来作为锁的,所以不会影响读操作
    synchronized (lock) {
        // 获取当前数组
        Object[] elements = getArray();
        int len = elements.length;
        // 对当前数组进行复制
        Object[] newElements = Arrays.copyOf(elements, len + 1);
        // 修改复制出来的数组
        newElements[len] = e;
        // 将数组引用重新指向这个修改后的数组
        setArray(newElements);
        return true;
    }
}

final void setArray(Object[] a) {
    elements = a;
}

可见,写操作也是非常简单的,因为同一时刻只能有一个线程进行写操作,所以这里使用了synchronized来进行同步。

总结

CopyOnWriteArrayList使用CopyOnWrite机制来实现了同步,比用锁性能更高。它也是采用了空间换时间的思想。但是,CopyOnWriteArrayList也有两个缺点:

  1. 内存问题,在写操作时因为要对数组进行复制,此刻内存中就会存在两份数据,这样会导致写的时候内存占用比较高,数据越多越明显;
  2. 数据一致性问题,不能保证数据的实时一致性,比如在读的时候并不能保证能读取到最新数据,它只能保证数据的最终一致性。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,366评论 11 349
  • 本系列出于AWeiLoveAndroid的分享,在此感谢,再结合自身经验查漏补缺,完善答案。以成系统。 Java基...
    济公大将阅读 1,537评论 1 6
  • Java SE 基础: 封装、继承、多态 封装: 概念:就是把对象的属性和操作(或服务)结合为一个独立的整体,并尽...
    Jayden_Cao阅读 2,140评论 0 8
  • 今天 一个特殊的日子 想给父亲送上一份可心的礼物 遗憾的是 子欲孝而亲不待! 想给父亲发上一句问候的话语 只是,人...
    细阳冰清阅读 520评论 1 2
  • 最近刚刚读完马伯庸的《三国机密》,一套分上下两册,体裁是小说,类似于《三国演义》。如果说《三国演义》是七分实三分虚...
    牛泳书海阅读 12,097评论 9 3