技术主题
线程池在日常工作中经常使用并发编程,线程池是必不可少的
技术原理
一、corePoolSize线程池核心线程大小
线程池中的一个最小的线程数量,即使这些线程处于空闲状态,他们也不会被销毁,除非设置了allowCoreThreadTimeOut
二、maximumPoolSize线程池最大线程数量
线程池能够容纳同时最大的线程数量,如果没有核心线程数,就会放入到工作队列中,直到工作队列满了,会创建线程来处理任务
三、keepAliveTime多余的空闲线程存活时间
只有当线程池中的线程数大于核心线程数,处于空闲状态,存活时间到过期
四、unit空闲线程存活时间单位
存活时间的单位
五、workQueue工作队列
-
ArrayBlockingQueue(数组的有界阻塞队列)
ArrayBlockingQueue 在创建时必须设置大小,按FIFO排序(先进先出)。新任务进来后,会放到该队列的队尾,有界的数组可以防止资源耗尽问题。当线程池中线程数量达到corePoolSize后,再有新任务进来,则会将任务放入该队列的队尾,等待被调度。如果队列已经是满的,则创建一个新线程,如果线程数量已经达到maxPoolSize,则会执行拒绝策略。 -
LinkedBloc