SynchronousQueue不存储元素,每个put操作需等待take操作完成,适用于生产者消费者直接传递数据的场景。1. 它无内部容量,插入和移除必须同步配对。2. 不支持null值,不能遍历。3. 常用于newCachedThreadPool线程池任务传递。4. 提供offer/poll等超时方法实现限时交互。5. 适合一对一同步传递,不适合缓冲或批量处理。示例中生产者调用put后阻塞,直到消费者调用take完成“握手”,数据直接传递。注意其性能依赖线程调度,调试困难因无中间状态。核心是理解其“只传递、不存储”的设计本质。

SynchronousQueue 是 Java 并发包 java.util.concurrent 中的一个特殊阻塞队列,它没有内部容量,每个插入操作必须等待另一个线程的对应移除操作,反之亦然。它适用于在生产者和消费者之间直接传递数据的场景,常用于线程池如 Executors.newCachedThreadPool() 中。
SynchronousQueue 不存储元素。当你调用 put() 方法时,该方法会阻塞,直到另一个线程调用 take() 来接收这个元素;同样,如果一个线程尝试 take(),它会一直等待直到有另一个线程执行 put()。这种“握手”机制实现了线程间直接的数据传递。
主要特点:
下面是一个简单的生产者和消费者通过 SynchronousQueue 通信的例子:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.SynchronousQueue;
public class SynchronousQueueExample {
public static void main(String[] args) {
SynchronousQueue<String> queue = new SynchronousQueue<>();
// 生产者线程
new Thread(() -> {
try {
System.out.println("生产者准备放入数据");
queue.put("Hello from producer");
System.out.println("数据已放入");
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}).start();
// 消费者线程
new Thread(() -> {
try {
System.out.println("消费者等待数据");
String data = queue.take();
System.out.println("收到数据: " + data);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}).start();
}
}
运行结果会显示两个线程“握手”成功,数据从生产者直接传递给消费者。
除了阻塞的 put/take,SynchronousQueue 还提供非阻塞或超时版本的方法:
示例:带超时的交互
new Thread(() -> {
try {
boolean success = queue.offer("Timeout data", 2, TimeUnit.SECONDS);
if (success) {
System.out.println("数据发送成功");
} else {
System.out.println("发送超时,无消费者接收");
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}).start();
new Thread(() -> {
try {
Thread.sleep(3000); // 故意延迟,使 offer 超时
String data = queue.poll(5, TimeUnit.SECONDS);
System.out.println("消费者最终收到: " + data);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}).start();
SynchronousQueue 最适合用于:
需要注意:
基本上就这些。SynchronousQueue 虽然不常用,但在特定高并发协作场景下非常高效。关键是要理解它“不存储、只传递”的本质。
以上就是在Java中如何使用同步队列SynchronousQueue的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号