线程池的实现原理 Java线程池实现原理
【线程池的实现原理 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,将执行拒绝策略 。
推荐阅读
- 电机电容坏了的表现 如何判断电容是否烧坏
- 栗子剥壳的方法 栗子剥壳有哪些方法
- 微信怎么查看删除的好友 微信如何查看删除的好友
- 氯气和碳酸钠的反应如何
- 骨灰为什么是粉红色的
- 要不要生二胎 生二胎的条件
- 苹果怎么返回原来的系统
- 电子驱蚊器有用吗 电器驱蚊器的原理
- 虫草菇的功效与作用
- 讲解员技巧 讲解员应具备的素质是什么