一、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可以通过构造函数指定该值),才会阻塞生产者队列,直到消费者从队列中消费掉一份数据,生产者线程会被唤醒,反之对于消费者这端的处理也基于同样的原理