SynchronousQueue 是不存储元素的阻塞队列,容量为0,核心语义是线程间直接交接;put()和take()必须配对等待,offer()和poll()仅在有配对线程时成功,否则立即返回;size()恒为0,不支持peek()、批量操作等。

SynchronousQueue 是 Java 并发包(java.util.concurrent)中一种特殊的阻塞队列,它**不存储元素**,每个插入操作必须等待另一个线程的对应移除操作,反之亦然。它的核心语义是“**直接交接**”,因此没有容量(capacity = 0),也不支持 peek()、iterator() 或批量操作。
核心方法:put(E e) —— 生产者阻塞等待消费者
将元素插入队列,但该操作不会返回,直到有另一个线程正在调用 take()(或 poll(long, TimeUnit))准备接收它:
- 如果当前有等待的消费者线程(即已调用
take()但尚未完成),则立即将元素传递过去,put()返回; - 否则,当前线程将被阻塞,直到有消费者来“接单”;
- 不接受
null元素,抛出NullPointerException; - 可响应中断,若等待中被中断则抛出
InterruptedException。
核心方法:take() —— 消费者阻塞等待生产者
从队列中移除并返回一个元素,但该操作会一直阻塞,直到有其他线程调用 put(E) 提供元素:
- 如果有等待的生产者线程(已调用
put()但未完成),则立即接收其元素,take()返回; - 否则,当前线程进入等待状态,直到有生产者“送货上门”;
- 同样可被中断,抛出
InterruptedException。
非阻塞/限时变体:offer(E e) 与 poll(long, TimeUnit)
这两个方法提供非阻塞或带超时的交互方式,适用于不想无限等待的场景:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~