这是线程池的构造方法,可以看得到,有很多的参数.
1.corePoolSize 核心线程数
2.maximumPoolSize 最大线程数
3.keepAliveTime 线程存活时间,当线程池里的线程数大于核心线程数时,如果等了存货时长还没有任务可执行,则线程退出。
4.TimeUnit unit 时间的单位
5.BlockingQueue workQueue 一个阻塞的任务队列
6.Executors.defaultThreadFactory(),线程工厂创建线程,命名等等.
7.defaultHandler 默认拒绝策略,线程池线程数达到最大线程数,任务队列也满了,就会触发拒绝策略 .
流程图如下:
四种jdk拒绝策略:
1.DiscardPolicy 直接丢弃这个任务。这个策略基本不会使用
2.AbortPolicy抛异常,不执行此任务,而且直接抛出一个运行时异常 RejectedExecutionException,为java线程池默认的阻塞策略。切记会中断调用者的处理过程,因此需要捕捉异常,否则程序会直接退出。
3.CallerRunsPolicy由调用者在调用的线程执行,一般在不允许失败的、对性能要求不高、并发量较小的场景下使用,因为线程池一般情况下不会关闭,也就是提交的任务一定会被运行,但是由于是调用者线程自己执行的,当多次提交任务时,就会阻塞后续任务执行,性能和效率自然就慢了。
4.DiscardOldestPolicy 丢弃队列最前面(最旧)的任务,然后重新尝试执行任务(重复此过程)
线程池执行流程
最新推荐文章于 2022-06-14 08:58:19 发布