1、java线程池的实现原理很简单,说白了就是一个线程集合workerSet和一个阻塞队列workQueue。当用户向线程池提交一个任务(也就是线程)时,线程池会先将任务放入workQueue中。workerSet中的线程会不断的从workQueue中获取线程然后执行。当workQueue中没有任务的时候,worker就会阻塞,直到队列中有任务了就取出来继续执行。
2、线程池的几个主要参数的作用
corePoolSize:规定线程池有几个线程(worker)在运行。
maximumPoolSize:当workQueue满了,不能添加任务的时候,这个参数才会生效。规定线程池最多只能有多少个线程(worker)在执行。
keepAliveTime:超出corePoolSize大小的那些线程的生存时间,这些线程如果长时间没有执行任务并且超过了keepAliveTime设定的时间,就会消亡。
unit:生存时间对于的单位
workQueue:存放任务的队列
threadFactory:创建线程的工厂
handler:当workQueue已经满了,并且线程池线程数已经达到maximumPoolSize,将执行拒绝策略。
锚定教育强国目标,绘就高质量发展新蓝图——专家解读《教育发展“十五五”规划》
主播说|高品质原酒越陈越值钱 现在却卖不动了?
主播说 | 前体操世界冠军吴柳芳首场带货直播,现场跳舞走模特步展示运动服饰
主播说丨夏天不够热 雪糕、冰激凌卖不动了吗?
活力中国调研行丨场景驱动创新 这座未来之城“拔节生长”
西汉楚国“文物天团”来北京了!大葆台遗址博物馆展览上新
冷评丨绿源电动车陷擦边视频争议,博流量不能丢了底线
主播说|乡镇宾馆叫“美如家”被索赔10万!因名字带“如家”俩字赔掉全年利润
主播说 | 茶饮品牌联名乙女游戏《恋与深空》,活动结束第二天游戏就爆雷
主播说丨女子哪吒车故障无法维修不能上路, “4S店让我把车卖了换新的”