Multi-Th:同步容器

作者: 甚了 | 来源:发表于2016-12-04 10:31 被阅读12次

ConcuttentHashMap

同步容器类在执行每个操作期间都持有一个锁。与HashMap一样,ConcurrentHashMap也是一个基于散列的Map,但是使用了一种完全不同的加锁策略来提供更高的并发性和伸缩性。

ConcurrentHashMap并不是将每个方法都在同一个锁上tong bu同步并使得每次只能有一个线程访问容器。而是使用一种粒度更细的加锁机制来实现更大程度的共享,这种机制是“分段锁”。在这种机制中,任意数量的读取线程可以并发的访问Map,执行读取操作的线程和执行写入的线程可以并发的访问Map,并且一定数量的写入线程可以并发的修改Map。

ConcurrentHashMap与其他同步容器:提供的迭代器不会抛出ConcurrentModificationException,因此不需要为迭代过程加锁。

尽管有很多的改进,但是对于整个Map进行计算的操作(例如:size()、isEmpty())会被削弱。由于size()返回的结果在计算时可能已经过期,它返回饿实际上是一个估计值。

在ConcurrentHashMap的实现中使用了一个包含16个锁的数组,每个锁保护所有散列桶的1/16,其中第N个散列桶由第(N mod 16)个锁来保护。如果散列函数具有合理的分布性,并且关键字能都实现均匀分布,那么这差不多能够把对锁的请求减少到原来的1/16

CopyOnWriteArrayList

CopyOnWriteArraySet

CopyOnWriteMap

“写入时复制”容器的线程安全性在于,只要正确的发布一个事实不可变的对象,那么在访问该对象时就不再需要进一步的同步。在每次修改时,都会创建并重新发布一个新的容器副本,从而实现可变性。

BlockingQueue

put和take方法回阻塞,offer和poll支持定时。

  • put 方法在队列已满时,将阻塞直到有空间可用;
  • take 方法在队列为空时,将阻塞直到有元素可用;

阻塞队列支持 “生产者-消费者”模式。(Executor任务框架中体现了这种模式)

BlockingQueue有多种实现,LinkedBlockingQueue、ArrayBlocking、PriorityBlockingQueue、SynchronousQueue

SynchronousQueue : 并不是真正的队列,实际上它维护的是一组线程,而不是存储空间,这些线程等待着把元素加入或者移出队列。这种实现方式,可以直接交付工作,从而降低了将数据从生产者移动到消费者的延迟。

BlockingDeque

双端队列,应用于“工作密取”模式,与“生产者-消费者”模式不同,在该模式中,每个消费者都有各自的的双端队列。如果一个消费者完成了自己双端队列的工作,那么它可以从其他消费者双端队列末尾秘密的获取工作,这样消费者间并不会发生竞争。

双端队列具体实现 ArrayDeque、LinkedBlockingDeque

相关文章

  • Multi-Th:同步容器

    ConcuttentHashMap 同步容器类在执行每个操作期间都持有一个锁。与HashMap一样,Concurr...

  • 2018-06-21 基础构建模块

    5.1 同步容器类 同步容器类包括Vector和Hashtable 5.1.1 同步容器类的问题 同步容器类都是线...

  • Multi-Th:同步工具-栅栏

    栅栏(Barrier) 通过闭锁可以启动一组操作,或者等待一组操作结束。闭锁是一次性对象,一旦进入结束状态就不能被...

  • 《Java并发编程实战》学习笔记--并发容器类

    《Java并发编程实战》学习笔记--同步容器类前面介绍了同步容器类,下面来说说并发容器类。 同步容器类:将所有对容...

  • 19.同步容器和并发容器

    [TOC] 同步容器类 早期的同步容器类包括Vector(ArrayList的同步版本),Hashtable(早期...

  • Multi-Th:同步工具类-闭锁

    闭锁 闭锁是一种同步工具类,可以延迟线程的进度直到线程到达终止状态。可以用于确保某些活动直到其他活动都完成后继续执...

  • 同步容器、并发容器及使用

    1.什么是同步容器?同步容器使用什么方式实现线程安全 同步容器可以简单的理解位通过synchronized来实现同...

  • 同步容器,并发容器,复合操作

    一、同步容器同步容器包括两类:Vector、Hashtable、Stack同步的封装器类由 Collections...

  • 并发编程

    同步容器 1、同步容器的思路:隐藏状态、对象访问加锁2、同步容器单个操作都是线程安全的,但是复合操作不是线程安全的...

  • 5. 基础构建模块

    5.1 同步容器类 同步容器类包括Vector和HashTable以及Collection.synchronize...

网友评论

    本文标题:Multi-Th:同步容器

    本文链接:https://www.haomeiwen.com/subject/hpkhmttx.html