(五)java 线程池工作队列

本文深入探讨Java线程池中的工作队列,重点介绍BlockingQueue接口及其四个主要实现:ArrayBlockingQueue、LinkedBlockingQueue、DelayQueue和SynchronousQueue。这些阻塞队列在并发处理中起到关键作用,各有特性,如ArrayBlockingQueue的固定容量,LinkedBlockingQueue的无锁设计,DelayQueue的延迟处理,以及SynchronousQueue的零容量特性。
摘要由CSDN通过智能技术生成

线程池工作队列

  上一章我们介绍了线程的基本情况,这一章进一步了解线程池中的工作队列,BlockingQueue 队列。

在类 Executors 中,我们可以看到不同线程池维护的工作队列是不同的,如newCachedThreadPool使用的是SynchronousQueue 同步队列,newSingleThreadScheduledExecutor使用DelayedWorkQueue
newFixedThreadPoolnewScheduledThreadPool使用LinkedBlockingQueue。它们都是实现了并发包java.util.concurrent中的BlockingQueue,下面说说这个接口。

BlockingQueue 阻塞队列

继承于队列 Queue,遵循先进先出原则(FIFO),队列提供几种基本的操作,添加元素(队尾)、移除元素(队头)、取出队头元素(不移除),每种操作都有两个方法,一种有可能抛异常,一种返回操作成功或失败。

在这个基础上,阻塞队列增加了操作锁,保证了数据安全,当然这个具体实现是在子类中完成,接口仅仅描述方法的特点,还增加两种不同的操作实现。下面描述这四种不同类型的操作:

  1. 操作,可能抛异常
  2. 操作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值