Java - 线程池参数

ThreadPoolExecutor

ThreadPoolExecutor是线程池的真正实现,他通过构造方法的一系列参数(不同的构造方法),来构成不同配置的线程池。

 

构造方法参数

  • corePoolSize

    核心线程数,默认情况下核心线程会一直存活,即使处于闲置状态也不会受存keepAliveTime限制。除非将allowCoreThreadTimeOut设置为true。有任务来之后,就会创建一个线程去执行任务,当线程池中的线程数目达到corePoolSize后,就会把到达的任务放到缓存队列当中,任务队列也满了,就看maximumPoolSize了

  • maximumPoolSize

    线程池所能容纳的最大线程数。超过这个数的线程将被阻塞。当任务队列为没有设置大小的LinkedBlockingDeque时,这个值无效。

  • keepAliveTime

    线程空闲时间达到keepAliveTime时,线程会退出,直到线程数量=corePoolSize;如果参数allowCoreThreadTimeout=true,则会直到线程数量=0;

  • unit

    keepAliveTime的单位。

  • workQueue

    线程池中的任务队列.

    常用的有SynchronousQueue,LinkedBlockingDeque,ArrayBlockingQueue

  • threadFactory

    线程工厂,创建线程的

  • RejectedExecutionHandler

   拒绝策略,是一个接口,可以自己实现自定义的拒绝策略。

  •   两种情况会拒绝处理任务:

               当线程数已经达到maxPoolSize,切队列已满,会拒绝新任务

             当线程池被调用shutdown()后,会等待线程池里的任务执行完毕,再shutdown。如果在调用shutdown()和线程池真正shutdown之间提交任务,会拒绝新任务。

  •   具体策略(可自定义):

            - AbortPolicy 丢弃任务,抛运行时异常(默认)

            - CallerRunsPolicy 执行任务

            - DiscardPolicy 忽视,什么都不会发生

            - DiscardOldestPolicy 从队列中踢出最先进入队列(队列最前面)的任务

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值