并发学习笔记(四)——并发包(并发容器)

HashMap/List/Set

不是线程安全的容器。
可以使用Collections.synchronizedMap(Map map)进行包装,从而达到线程安全的目的,适合并发量比较小时使用。

	    public V get(Object key) {
            synchronized (mutex) {return m.get(key);}
        }

        public V put(K key, V value) {
            synchronized (mutex) {return m.put(key, value);}
        }

可以从源码看出,内部使用synchronized进行同步,从而变成串行化的一个容器,并发量不会特别高,因为都是互斥的。

ConcurrentHashMap(线程安全+高并发)

HashMap原理

内部存储结构是Entry(Key、Value、Next域)数组,每个下标位置是链表结构(防止Hash冲突)。

实现

(1)Segment,相当于小的HashMap,一个线程过来操作的是该Segment,而不是整个HashMap,最后在合并。
(2)Segment继承自ReentrantLock,在源码中存在大量的tryLock,很少Lock,保证了高并发。
(3)size操作时,需要拿到所有Segment的锁,统计数据,再释放锁,所以ConcurrentHashMap少用Size。

BlockingQueue(仅线程安全)

阻塞队列,不是高性能的并发容器,它是通常用于在多个线程中共享数据的队列,适用于生产者消费者模型。
若队列为空,则读数据的线程会等待;若队列为满,则写数据的线程会等待。类似于信号量。

ArrayBlockingQueue实现

    /** Main lock guarding all access */
    final ReentrantLock lock;

    /** Condition for waiting takes */
    private final Condition notEmpty;

    /** Condition for waiting puts */
    private final Condition notFull;

ReentrantLock主要做访问控制,notEmpty条件为通知可以,notFull条件为通知可以

ConcurrentLinkedQueue(线程安全+高并发)

内部使用大量的无锁的操作,很少直接使用lock而是循环使用tryLock。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值