Java中可以使用BlockingQueue
接口来实现阻塞队列。BlockingQueue
接口继承自Queue
接口,提供了阻塞队列的基本操作方法,并新增了一些阻塞等待的方法。
常用的BlockingQueue
的实现类有:
ArrayBlockingQueue
:基于数组的有界阻塞队列。LinkedBlockingQueue
:基于链表的可选有界或无界阻塞队列。PriorityBlockingQueue
:支持优先级排序的无界阻塞队列。DelayQueue
:延迟队列,元素只有在其指定的延迟时间到期时才能出队列。SynchronousQueue
:容量为0的阻塞队列,用于线程间直接交换数据。下面是使用ArrayBlockingQueue
实现阻塞队列的示例代码:
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
public class BlockingQueueExample {
public static void main(String[] args) {
// 创建一个容量为10的阻塞队列
BlockingQueue<Integer> queue = new ArrayBlockingQueue<>(10);
// 生产者线程
Thread producer = new Thread(() -> {
try {
for (int i = 0; i < 10; i++) {
queue.put(i); // 将元素放入队列
System.out.println("Produced: " + i);
Thread.sleep(1000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
// 消费者线程
Thread consumer = new Thread(() -> {
try {
for (int i = 0; i < 10; i++) {
int num = queue.take(); // 从队列中取出元素
System.out.println("Consumed: " + num);
Thread.sleep(2000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
// 启动生产者和消费者线程
producer.start();
consumer.start();
try {
// 等待生产者和消费者线程执行完毕
producer.join();
consumer.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
在上述示例中,生产者线程通过put()
方法将元素放入队列,如果队列已满,则会阻塞等待;消费者线程通过take()
方法从队列中取出元素,如果队列为空,则会阻塞等待。