Java线程池的七个参数以及原理
java多线程开发时,常常⽤到线程池技术,这篇⽂章是对创建java线程池时的七个参数的详细解释。
从源码中可以看出,线程池的构造函数有7个参数,分别是corePoolSize、maximumPoolSize、keepAliveTime、unit、workQueue、threadFactory、handler。下⾯会对这7个参数⼀⼀解释。
⼀、corePoolSize 线程池核⼼线程⼤⼩
线程池中会维护⼀个最⼩的线程数量,即使这些线程处理空闲状态,他们也不会被销毁,除⾮设置了allowCoreThreadTimeOut。这⾥的最⼩线程数量即是corePoolSize。
⼆、maximumPoolSize 线程池最⼤线程数量
⼀个任务被提交到线程池以后,⾸先会有没有空闲存活线程,如果有则直接将任务交给这个空闲线程来执⾏,如果没有则会缓存到⼯作队列(后⾯会介绍)中,如果⼯作队列满了,才会创建⼀个新线程,然后从⼯作队列的头部取出⼀个任务交由新线程来处理,⽽将刚提交的任务放⼊⼯作队列尾部。线程池不会⽆限制的去创建新线程,它会有⼀个最⼤线程数量的限制,这个数量即由maximunPoolSize指定。
三、keepAliveTime 空闲线程存活时间
⼀个线程如果处于空闲状态,并且当前的线程数量⼤于corePoolSize,那么在指定时间后,这个空闲线程会被销毁,这⾥的指定时间由keepAliveTime来设定
四、unit 空闲线程存活时间单位
keepAliveTime的计量单位
五、workQueue ⼯作队列
新任务被提交后,会先进⼊到此⼯作队列中,任务调度时再从队列中取出任务。jdk中提供了四种⼯作队列:
①ArrayBlockingQueue
基于数组的有界阻塞队列,按FIFO排序。新任务进来后,会放到该队列的队尾,有界的数组可以防⽌资源耗尽问题。当线程池中线程数量达到corePoolSize后,再有新任务进来,则会将任务放⼊该队列的队尾,等待被调度。如果队列已经是满的,则创建⼀个新线程,如果线程数量已经达到maxPoolSize,则会执⾏拒绝策略。
②LinkedBlockingQuene
基于链表的⽆界阻塞队列(其实最⼤容量为Interger.MAX),按照FIFO排序。由于该队列的近似⽆界性,当线程池中线程数量达到corePoolSize后,再有新任务进来,会⼀直存⼊该队列,⽽不会去创建新线程直到maxPoolSize,因此使⽤该⼯作队列时,参数maxPoolSize其实是不起作⽤的。
③SynchronousQuene
⼀个不缓存任务的阻塞队列,⽣产者放⼊⼀个任务必须等到消费者取出这个任务。也就是说新任务进来时,不会缓存,⽽是直接被调度执⾏该任务,如果没有可⽤线程,则创建新线程,如果线程数量达到maxPoolSize,则执⾏拒绝策略。
④PriorityBlockingQueue
具有优先级的⽆界阻塞队列,优先级通过参数Comparator实现。
六、threadFactory 线程⼯⼚
创建⼀个新线程时使⽤的⼯⼚,可以⽤来设定线程名、是否为daemon线程等等
七、handler 拒绝策略
java线程池创建的四种
当⼯作队列中的任务已到达最⼤限制,并且线程池中的线程数量也达到最⼤限制,这时如果有新任务提交进来,该如何处理呢。这⾥的拒绝策略,就是解决这个问题的,jdk中提供了4中拒绝策略:
①CallerRunsPolicy
该策略下,在调⽤者线程中直接执⾏被拒绝任务的run⽅法,除⾮线程池已经shutdown,则直接抛弃任务。
②AbortPolicy
该策略下,直接丢弃任务,并抛出RejectedExecutionException异常。
③DiscardPolicy
该策略下,直接丢弃任务,什么都不做。
④DiscardOldestPolicy
该策略下,抛弃进⼊队列最早的那个任务,然后尝试把这次拒绝的任务放⼊队列

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。