在多线程编程中,我们经常需要使用队列来实现线程间的数据共享。而阻塞队列是一种特殊的队列,当队列为空时,从队列中获取元素的操作会被阻塞;当队列满时,往队列中添加元素的操作会被阻塞。这样可以有效地控制线程之间的协作和同步。
ArrayBlockingQueue 和 LinkedBlockingQueue 都是 Java 并发包提供的线程安全的阻塞队列实现,它们提供了不同的特性和适用场景。
import java.util.concurrent.ArrayBlockingQueue;
public class ArrayBlockingQueueExample {
public static void main(String[] args) throws InterruptedException {
// 创建一个容量为3的ArrayBlockingQueue
ArrayBlockingQueue<Integer> queue = new ArrayBlockingQueue<>(3);
// 往队列中添加元素
queue.put(1);
queue.put(2);
queue.put(3);
// 队列已满,添加操作会被阻塞
queue.put(4);
// 从队列中获取元素
int element = queue.take();
System.out.println("取出元素:" + element);
// 队列已空,获取操作会被阻塞
int element2 = queue.take();
}
}
import java.util.concurrent.LinkedBlockingQueue;
public class LinkedBlockingQueueExample {
public static void main(String[] args) throws InterruptedException {
// 创建一个容量为3的LinkedBlockingQueue
LinkedBlockingQueue<Integer> queue = new LinkedBlockingQueue<>(3);
// 往队列中添加元素
queue.put(1);
queue.put(2);
queue.put(3);
// 队列已满,添加操作会被阻塞
queue.put(4);
// 从队列中获取元素
int element = queue.take();
System.out.println("取出元素:" + element);
// 队列已空,获取操作会被阻塞
int element2 = queue.take();
}
}
ArrayBlockingQueue 和 LinkedBlockingQueue 是 Java 并发包提供的线程安全的阻塞队列实现。它们分别基于数组和链表来存储元素,并提供了不同的特性和适用场景。ArrayBlockingQueue 适合读写性能较高、固定容量的场景;而 LinkedBlockingQueue 适合插入和删除性能较高、可选有界或无界的场景。在使用时需要根据具体需求选择合适的队列实现。
[1]
首发博客地址: https://blog.zysicyj.top/
[2]
面试题手册: https://store.amazingmemo.com/chapterDetail/1685324709017001
[3]
系列文章地址: https://blog.zysicyj.top/categories/技术文章/后端技术/系列文章/面试题精讲/
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有