在Java中,可以使用BlockingQueue
接口来实现阻塞队列。BlockingQueue
接口继承自Queue
接口,它提供了一种线程安全的队列实现,支持在队列为空时等待元素被添加,或者在队列已满时等待空间被释放。
常用的BlockingQueue
实现类包括ArrayBlockingQueue
、LinkedBlockingQueue
、PriorityBlockingQueue
等。
以下是一个使用ArrayBlockingQueue
实现阻塞队列的示例:
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
public class BlockingQueueExample {
public static void main(String[] args) {
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);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
// 消费者线程
Thread consumer = new Thread(() -> {
try {
for (int i = 0; i < 10; i++) {
int value = queue.take(); // 从队列中取出元素
System.out.println("Consumed: " + value);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
producer.start();
consumer.start();
}
}
在上面的示例中,生产者线程向ArrayBlockingQueue
中添加元素,消费者线程从队列中取出元素。如果队列已满或者为空时,线程会被阻塞,直到队列中有空间或者有元素可取。