共计 1197 个字符,预计需要花费 3 分钟才能阅读完成。
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()
方法从队列中取出元素,如果队列为空,则会阻塞等待。
丸趣 TV 网 – 提供最优质的资源集合!
正文完