ConcurrentMap与CopyOnWrite容器

说到ConcurrentMap,一定要先说HashMap和HashTable,看面试题我们也会背了,什么HashMap线程不安全,HashTable线程安全,HashMap效率高,HashTable效率低.那么为什么HashTable效率低,线程安全?

上HashTable的put方法.↓↓↓↓↓

    public synchronized V put(K key, V value) {
       ..........
    }

上面一看就知道,HashTable的put方法用了synchronized来保证线程安全,不仅仅是put,还包括get,contains等等,自己去看jdk源码~~

那么这种采用同步的方式,显然高并发的场景下效率极其低下,所以在jdk5的时候,出了一个牛逼的工具包concurent,利用ConcurrentMap.ConcurrentMap有两个重要的实现:
ConcurrentHashMap和ConcurrentSkipListMap(支持并发排序,弥补ConcurrentHashMap).ConcurrentHashMap内部使用段来表示这些不同的部分,每个段其实就是一个HashTable,他们有自己的锁.只要多个修改操作发生在不同的段上,它们就可以并发进行.把一个整体分成了16个段.也就是最高支持16个线程的并发修改操作.这也是在多线程场景时减小锁的粒度从而降低锁竞争的一种方案.并且代码中大多共享变量使用volatile关键字声明,目的是第一时间获取修改的内容,性能非常的好.

当然啦,如果有两个线程同时操作同一个段,那么肯定是会被阻塞着~具体实现看源码吧还是挺复杂的~

然后是CopyOnWrite容器,和上面一样,对应着也有线程安全的Vector,集合中的线程安全类.看jdk源码↓↓↓↓↓

    public synchronized E get(int index) {
        ..............
    }

Vector的get方法,add方法等等也是加了synchronized修饰来保证线程安全.那么CopyOnWrite是如何实现的呢?

(简书不能画图- -,只能手写思想,不懂就多读几遍..)

CopyOnWrite容器是当我们往一个容器中添加元素的时候,不直接往当前容器添加,而是先将当前容器进行copy,复制出新的容器,然后新的容器里添加元素,添加完元素之后,再将原容器的引用指向新的容器.这样做的好处是我们可以对CopyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素,所以CopyOnWrite容器也是一种读写分离的思想,读和写不同的容器.(面试的时候问,直接说最后一句话就可以了~~~~)

CopyOnWrite也有两种实现:CopyOnWriteArrayList和CopyOnWriteArraySet

来看看CopyOnWriteArrayList底层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();
        }
    }

ReentrantLock是重入锁,是为了保证写安全,所以不会出现多个写的问题!为什么不用ReentrantReadWriteLock读写锁,因为ReentrantLock效率高啊,只能这么想,也不知道写jdk源码的人怎么想.至于这个锁,将来讲~~

关于CopyOnWrite有一点要说的是,使用CopyOnWrite适合读多写少的场景,你想,如果容器有1000个元素去copy那代价太大了还不如用同步,是吧

有啥不懂的请加qq727865942,微信号 cto_zej,觉得是干货请打赏~~~~~~~~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,204评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,091评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,548评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,657评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,689评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,554评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,302评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,216评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,661评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,851评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,977评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,697评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,306评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,898评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,019评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,138评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,927评论 2 355

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,246评论 11 349
  • Java8张图 11、字符串不变性 12、equals()方法、hashCode()方法的区别 13、...
    Miley_MOJIE阅读 3,707评论 0 11
  • 锁 锁是用来控制多个线程访问共享资源的方式,一般来说,一个锁能够防止多个线程同时访问共享资源(但是有些锁可以允许多...
    黄俊彬阅读 1,483评论 1 15
  • 人一生中要完成许多事情,事情有分大小,每一件事想要做好都不是那么容易的。有的人却可以出类拔萃,能够在自己的领域做到...
    吉日良辰阅读 468评论 4 4
  • 秀丽笔写出来的感觉,像是毛笔,但还是和毛笔不同。 这个印……刻出来的,鹤不像鹤鸡不像鸡。 用木刻刀琢磨一下午。手边...
    不吃炒蛋脱你胖次阅读 337评论 0 1