> 职场
线程池的实现原理 Java线程池实现原理
1、java线程池的实现原理很简单,说白了就是一个线程集合workerset和一个阻塞队列workqueue。当用户向线程池提交一个任务(也就是线程)时,线程池会先将任务放入workqueue中。workerset中的线程会不断的从workqueue中获取线程然后执行。当workqueue中没有任务的时候,worker就会阻塞,直到队列中有任务了就取出来继续执行。
2、线程池的几个主要参数的作用
corepoolsize: 规定线程池有几个线程(worker)在运行。
maximumpoolsize: 当workqueue满了,不能添加任务的时候,这个参数才会生效。规定线程池最多只能有多少个线程(worker)在执行。
keepalivetime: 超出corepoolsize大小的那些线程的生存时间,这些线程如果长时间没有执行任务并且超过了keepalivetime设定的时间,就会消亡。
unit: 生存时间对于的单位
workqueue: 存放任务的队列
threadfactory: 创建线程的工厂
handler: 当workqueue已经满了,并且线程池线程数已经达到maximumpoolsize,将执行拒绝策略。