阻塞队列(BlockingQueue) 是一个支持两个附加操作的队列。这两个附加的操作是:在队列为空时,获取元素的线程会等待队列变为非空。
当队列满时,存储元素的线程会等待队列可用。阻塞队列常用于生产者和消费者的场景,生产者是往队列里添加元素的线程,消费者是从队列里拿元素的线程。
阻塞队列就是生产者存放元素的容器,而消费者也只从容器里拿元素。
使用场景: 多线程并发处理,线程池!
队列 FIFO先进先出 一端写入一端取出
写入如果队列满了就必须阻塞等待 如果队列是空的必须阻塞等待生产
注意:BlockingQueue 不接受null值 试图添加一个null元素时会抛出异常
BlockingQueue 可以是限定容量的 超过给定容量时是无法添加的
- ArrayBolckingQueue(常用):基于数组的有界阻塞队列
- LinkedBlockingQueue(常用):基于链表的有界阻塞队列 大小默认为 Integer最大值
- PriorityBlockingQueue : 一个支持优先级排序的无界阻塞队列。
- DelayQueue: 使用优先级队列实现的延迟无界阻塞队列
- SynchronousQueue: 一个不存储元素的阻塞队列。
- LinkedTransferQueue: 一个由链表结构组成的无界阻塞队列。
- LinkedBlockingDeque: 一个由链表结构组成的双向阻塞队列
阻塞队列核心方法
演示各个API的使用
第一组会抛出异常API演示 add remove element
第二组API使用
第三组阻塞API使用
放不进去了会一直阻塞直到有空位
第四组API使用
设置阻塞时间 超过阻塞时间没放进去就放弃等待
到此这篇关于java中的BlockingQueue(阻塞队列)解析的文章就介绍到这了,更多相关BlockingQueue阻塞队列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
到此这篇java阻塞队列实现(java阻塞是什么意思)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/jjc/12368.html