java util下的并发包_java.util.concurrent并发包

一、ReentrantReadWriteLock读写锁

private final ReadWriteLock rw = new ReentrantReadWriteLock();

private final Lock r = rw.readLock();

private final Lock w = rw.writeLock();

说明:一个资源能够被多个读线程访问,或者被一个写线程访问,但是不能同时存在读写线程

二、java.util.concurrent.ConcurrentHashMap

三、BlockingQueue 阻塞队列

转载:http://wsmajunfeng.iteye.com/blog/1629354

Concurrent包中,BlockingQueue很好的解决了多线程中,如何高效安全“传输”数据的问题。

几种实现:

(1)ArrayBlockingQueue:

基于数组的阻塞队列实现,在ArrayBlockingQueue内部,维护了一个定长数组,以便缓存队列中的数据对象,这是一个常用的阻塞队列,除了一个定长数组外,ArrayBlockingQueue内部还保存着两个整形变量,分别标识着队列的头部和尾部在数组中的位置。

(2)LinkedBlockingQueue       基于链表的阻塞队列,同ArrayListBlockingQueue类似,其内部也维持着一个数据缓冲队列(该队列由一个链表构成),当生产者往队列中放入一个数据时,队列会从生产者手中获取数据,并缓存在队列内部,而生产者立即返回;只有当队列缓冲区达到最大值缓存容量时(LinkedBlockingQueue可以通过构造函数指定该值),才会阻塞生产者队列,直到消费者从队列中消费掉一份数据,生产者线程会被唤醒,反之对于消费者这端的处理也基于同样的原理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值