线程池ThreadPoolExecutor知识

一、使用线程池的好处

  降低资源消耗,提高响应速度,提高线程的客观理性。

二、ThreadPoolExecutor的核心参数

  corePoolSize:核心线程数

  maximumPoolSize:最大线程数

  workQueue:任务队列,当线程数量已经达到,corePoolSize时,新的任务会加入该队列。

  keepAliveTime:存活时间,即空闲的线程经过多久会被回收掉  

  unit:keepAliveTime的时间单位

  threadFactory:创建线程的工厂

  handler:拒绝策略(饱和策略),下面解释。

三、ThreadPoolExecutor的工作流程

四、ThreadPoolExecutor的四种拒绝策略

  当线程池的线程数量已经达到线程池配置的最大线程数时,再有任务进入时会执行拒绝策略。

①AbortPolicy:抛出RejectExecution的异常

②CallerRunsPolicy:将被拒绝的任务直接在调用者线程中执行,这样能保证任务不丢失,但会影响执行速度

 ③DiscardPolicy:直接丢弃该任务

 ④DiscardOldestPolicy:丢弃最早未处理的任务。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值