0
点赞
收藏
分享

微信扫一扫

线程池的拒绝策略有哪些?线程池有哪几种工作队列?

一、线程池的拒绝策略有哪些?

1、AbortPolicy:直接抛出异常,默认使用此策略。

2、CallerRunsPolicy:用调用者所在得线程来执行任务;

3、DiscardOldestPolicy:丢弃阻塞队列里最老的任务,也就是队列里面靠前的任务;

4、DiscardPolicy:直接丢弃当前任务。

想实现自己的拒绝策略,实现RejectedExceptionHandler接口。

二、线程池有哪几种工作队列?

常用的阻塞队列主要用以下几种:

线程池的拒绝策略有哪些?线程池有哪几种工作队列?_执行时间

ArrayBlockingQueue:ArrayBlockingQueue(有界队列)是一个用数组实现的有界阻塞队列,按FIFO排序量。

LinkedBlockingQueue:LinkedBlockingQueue(可设置容量队列)是基于链表结构的阻塞队列,按FIFO排序任务,容量可以选择进行设置,不设置的话,将是一个无边界的阻塞队列,最大长度为Integer.MAX_VALUE,吞吐量通常要高于

ArrayBlockingQuene;newFixedThreadPool线程池使用了这个队列

DelayQueue:DelayQueue(延迟队列)是一个任务定时周期的延迟执行的队列。根据指定的执行时间从小到大排序,否则根据插入到队列的先后排序。

newScheduledThreadPool线程池使用了这个队列。

PriorityBlockingQueue:PriorityBlockingQueue(优先级队列)是具有优先级的无界阻塞队列

SynchronousQueue:SynchronousQueue(同步队列)是一个不存储元素的阻塞队列,每个插入操作必须等到另一个线程调用移除操作,否则插入操作一直处于阻塞状态,吞吐量通常要高于LinkedBlockingQuene,newCachedThreadPool线程池使用了这个队列。

举报

相关推荐

0 条评论