java线程池ThreadPoolExecutor使用

java线程池ThreadPoolExecutor使用

ThreadPoolExecutor
参数名 作用
corePoolSize 核心线程池大小
maximumPoolSize 最大线程池大小
keepAliveTime 线程池中超过corePoolSize数目的空闲线程最大存活时间;可以allowCoreThreadTimeOut(true)使得核心线程有效时间
TimeUnit keepAliveTime时间单位
workQueue 阻塞任务队列
RejectedExecutionHandler 当提交任务数超过maxmumPoolSize+workQueue之和时,任务会交给RejectedExecutionHandler来处理

//创建线程池
ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(
1, 
5, 
0L, 
TimeUnit.MILLISECONDS,
 new LinkedBlockingDeque<>(10),
 new DiscardPolicy()
 );


从线程池获取线程
   threadPoolExecutor.execute(()->{
  			//这里写你要执行的代码
    });

BlockingQueue workQueue:阻塞队列。 当前核心线程达到最大值时,优先向阻塞队列进行填充。

  1. LinkedBlockingQueue 链式阻塞队列,底层数据结构是链表,默认大小是Integer.MAX_VALUE,也可以指定大小。
  2. ArrayBlockingQueue 数组阻塞队列,底层数据结构是数组,需要指定队列的大小。
  3. SynchronousQueue 同步队列,内部容量为0,每个put操作必须等待一个take操作,反之亦然。
  4. DelayQueue 延迟队列,该队列中的元素只有当其指定的延迟时间到了,才能够从队列中获取到该元素 。

RejectedExecutionHandler handler:拒绝策略。当线程达到最大线程数时,将采用拒绝策略处理后续的任务。

  1. ThreadPoolExecutor.AbortPolicy:默认拒绝处理策略,丢弃任务并抛出RejectedExecutionException异常。
  2. ThreadPoolExecutor.DiscardPolicy:丢弃新来的任务,但是不抛出异常。
  3. ThreadPoolExecutor.DiscardOldestPolicy:丢弃队列头部(最旧的)的任务,然后重新尝试执行程序(如果再次失败,重复此过程)。
  4. ThreadPoolExecutor.CallerRunsPolicy:由调用线程处理该任务。

shutdown和shutdownNow的区别

  1. 调用shutdown()方法后线程池不能接受新的任务,清除一些空闲worker,不会等待阻塞队列的任务完成。
  2. 调用shutdownNow()方法后线程池不能接受新的任务,中断所有线程,阻塞队列中没有被执行的任务全部丢弃。此时,poolsize=0,阻塞队列的size也为0
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值