SynchronousQueue,阻塞队列的一种,单个元素的队列,没有容量,与其他阻塞队列不同,SynchronousQueue是一个不存储元素的阻塞队列,每一个put操作必须要等待一个take操作,否则不能继续添加元素,反之亦然,也可叫做零库存阻塞队列,来一个demo,更加深刻理解。
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.SynchronousQueue;
import java.util.concurrent.TimeUnit;public class SynchronousQueueDemo {
public static void main(String[] args) {
BlockingQueue<String> blockingQueue = new SynchronousQueue<>();
new Thread(() -> {
try {
System.err.println(Thread.currentThread().getName() + "put a");
blockingQueue.put("a");System.err.println(Thread.currentThread().getName() + "put b");
blockingQueue.put("b");System.err.println(Thread.currentThread().getName() + "put c");
blockingQueue.put("c");
} catch (InterruptedException e) {
e.printStackTrace();
}
}, "t1\t").start();new Thread(() -> {
try {
TimeUnit.SECONDS.sleep(5);
System.err.println(Thread.currentThread().getName() + "\tget " + blockingQueue.take());TimeUnit.SECONDS.sleep(5);
System.err.println(Thread.currentThread().getName() + "\tget " + blockingQueue.take());TimeUnit.SECONDS.sleep(5);
System.err.println(Thread.currentThread().getName() + "\tget " + blockingQueue.take());
} catch (InterruptedException e) {
e.printStackTrace();
}
}, "t2").start();}
}
从执行结果来看,线程1put一个数据后,阻塞在那,只有等到线程2在5秒后消费完后,线程1才可以继续put数据,做到了,put一个,消费一个,put一个,消费一个的生产者消费者的模式。
t1 put a
t2 get a
t1 put b
t2 get b
t1 put c
t2 get c
使用过Object类的wait方法,和notify方法来自己控制线程等待,唤醒的小伙伴,一定会体会到这个类的方便性,好了,下篇见。