当前位置: 首页 > news >正文

Java面试篇基础部分- Java中的阻塞队列

  首先队列是一种前进后出的操作结构,也就是说它只允许从队列前端进入,从队列后端退出。这个前端和后端看个人如何理解,也就是通常所说的入队和出队,队头和队尾。

  阻塞队列和一般队列的不同就在于阻塞队列是可以阻塞的,这里所说的并不是说队列中间或者队头队尾被拦截了,而是一种操作队列的线程的一种状态。在阻塞队列中,线程阻塞有两种情况。

  • 消费者阻塞:也就是说,在队列为空的时候,没有任何数据的时候,队列消费者端就会被自动阻塞,一直到有任务进入到队列之后,消费者的线程就会被自动的唤起来消费任务。
    在这里插入图片描述
  • 生产者阻塞: 在队列已经满了,或者是没有可用空间的时候,生产者端的线程都会被阻塞,直到队列中的线程被消耗,有位置进入的时候,线程被自动唤醒,并且生产数据。
    在这里插入图片描述
      二者分别对应的出队,入队操作,当队列为空的时候,出队阻塞,当队列满的时候,入队阻塞。

阻塞队列的主要操作

  阻塞队列的主要操作有插入操作和移除操作。插入操作有add()、offer()、put(),移除操作有 remove()、poll()、take() 具体如下。

  1、插入操作

  public abstract boolean add(E paramE) ;将指定的元素插入到队列中,在成功的时候返回true,如果当前没有可用的空间,就会抛出IllegalStateException。如果该元素是null,就会抛出NullPointException的异常。

public boolean add(E e) {// 添加元素成功,返回 trueif (offer(e))return true;// 添加元素失败,抛出异常elsethrow new IllegalStateException("Queue full");}

  public abstract boolean offer(E paramE);将指定的元素插入队列中,在成功的时候返回true,如果没有可以用的空间,则返回false。源码如下

 public boolean offer(E e) {// 检查元素是否为空checkNotNull(e);final ReentrantLock lock = this.lock;// 获取锁操作lock.lock();try {// 如果队列满了,则返回falseif (count == items.length)return false;else {// 如果队列为空,则将元素加入到队列中enqueue(e);return true;}} finally {// 操作成功释放锁lock.unlock();}}

  offer(E o,long timeout,TimeUnit unit);将指定的元素插入到队列中,可以设置等待时间,如果在设定的等待时间内不能向队列中加入这个元素,就会返回false

public boolean offer(E e, long tim
http://www.lryc.cn/news/445146.html

相关文章:

  • Go语言并发编程之Channels详解
  • 【Java集合】LinkedList
  • 大模型之基准测试集(Benchmark)-给通义千问2.0做测评的10个权威测基准测评集
  • 解决selenium爬虫被浏览器检测问题
  • 计算机前沿技术-人工智能算法-大语言模型-最新论文阅读-2024-09-17
  • LLM - 理解 多模态大语言模型(MLLM) 的 幻觉(Hallucination) 与相关技术 (七)
  • 如何在C++中实现RDP协议的屏幕更新功能?
  • Tornado 是一个 Python 异步网络库和 web 框架
  • 鹏哥C语言49---第5次作业:选择语句 if 和 switch
  • 通过 Flink 的火焰图定位反压
  • 初识爬虫8
  • Unity SRP 可编程渲染管线的基本用法
  • AutoX.js向后端传输二进制数据
  • lvgl学习笔记--基础对象1
  • TDengine 在业务落地与架构改造中的应用实践!
  • Python3爬虫教程-HTTP基本原理
  • 竹云赋能“中国·贵州”全省统一移动应用平台建设,打造政务服务“新引擎”
  • 【MySQL 04】数据类型
  • 夹耳式蓝牙耳机哪个牌子最好,教你如何不踩雷
  • 亿发零售云解析:新零售破局与年轻群体消费趋势变化
  • zabbix“专家坐诊”第257期问答
  • 【代码笔记】
  • CentOS上使用Mosquitto实现Mqtt主题消息发布和订阅mqtt主题消息连同时间戳记录到文件
  • COMTRADE 录波文件 | 可视化工具 | 电能质量查看软件
  • 【面试宝典】面试基础指导
  • Linux·权限与工具-git与gdb
  • unity 如何 团队协作避免文件冲突?
  • VOC2007 的ImageSets/Main目录下通常有四个文件test.txt val.txt train.txt trainval.txt
  • JavaScript中的parseInt(), Number(),+有啥区别?
  • java核心基础