BlockingQueue是实现生产者消费者模式的线程安全方式,其内部处理同步问题,生产者调用put阻塞入队,消费者调用take阻塞出队,队列满时生产者等待,队列空时消费者等待。
在Java中,BlockingQueue 是实现生产者消费者模式最简单且线程安全的方式。它内部已经处理了线程同步问题,生产者线程向队列添加元素,消费者线程从队列取出元素,当队列满时生产者自动阻塞,队列空时消费者自动阻塞。
BlockingQueue 是 java.util.concurrent 包中的接口,常用实现类有:
关键方法:
下面是一个使用 ArrayBlockingQueue 的简单示例:
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ArrayBlockingQueue;
// 共享数据
class Data {
private final int value;
public Data(int value) {
this.value = value;
}
@Override
public String toString() {
return "Data{" + "value=" + value + '}';
}
}
// 生产者
class Producer implements Runnable {
private final BlockingQueue queue;
public Producer(BlockingQueue
queue) {
this.queue = queue;
}
@Override
public void run() {
try {
for (int i = 1; i <= 5; i++) {
Data data = new Data(i);
queue.put(data); // 阻塞插入
System.out.println("生产者生产: " + data);
Thread.sleep(500); // 模拟耗时
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
}
// 消费者
class Consumer implements Runnable {
private final BlockingQueue queue;
public Consumer(BlockingQueue queue) {
this.queue = queue;
}
@Override
public void run() {
try {
while (true) {
Data data = queue.take(); // 阻塞取出
System.out.println("消费者消费: " + data);
Thread.sleep(1000); // 消费较慢
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
}
// 主程序
public class ProducerConsumerExample {
public static void main(String[] args) {
// 创建容量为3的阻塞队列
BlockingQueue queue = new ArrayBlockingQueue<>(3);
// 启动生产者和消费者线程
Thread producerThread = new Thread(new Producer(queue));
Thread consumerThread = new Thread(new Consumer(queue));
producerThread.start();
consumerThread.start();
// 可以设置运行时间后中断
try {
Thread.sleep(6000);
} catch (InterruptedException e) {
e.printStackTrace();
}
producerThread.interrupt();
consumerThread.interrupt();
}
}
使用 BlockingQueue 实现生产者消费者模式时需要注意以下几点:
基本上就这些。BlockingQueue 封装了复杂的线程协作逻辑,让开发者能更专注于业务本身。只要理解 put/take 的阻塞性质,就能轻松构建稳定高效的生产者消费者系统。