LinkedBlockingQueue也是BlockingQueue接口的一个实现类之一
这个属于基础性问题,老规矩,我们将从使用场景和代码示例来进行讲解
来,思考片刻,给出你的答案
1,使用场景
- 实现:基于链表实现的阻塞队列,可以选择是否设置容量上限,默认无界。
- 场景:适用于大多数生产和消费速率大致匹配的场景,如果需要有界的队列可以指定容量,否则默认为无界。
2,来,上代码
import java.util.concurrent.LinkedBlockingQueue;public class LinkedBlockingQueueExample {static final LinkedBlockingQueue<String> queue = new LinkedBlockingQueue<>();public static void main(String[] args) throws InterruptedException {Thread producer = new Thread(() -> {try {for (int i = 0; i < 20; i++) {String item = "Item " + i;queue.put(item); // 即使是无界队列,也可以通过put阻塞等待空间System.out.println("Produced: " + item);}} catch (InterruptedException e) {e.printStackTrace();}});Thread consumer = new Thread(() -> {try {while (true) {String item = queue.take(); // 无界队列情况下,take永远不会阻塞,直到被中断System.out.println("Consumed: " + item);}} catch (InterruptedException e) {e.printStackTrace();}});producer.start();consumer.start();// 等待producer完成producer.join();// 中断消费者consumer.interrupt();}
}
想提高面试准备效率!欢迎来加入我的星球!承诺三天内不满意,直接免费退出!