线程面试点
核心线程数,最大线程数,队列长度,过期时间,时间单位,拒绝策略
如果线程反复创建销毁创建销毁 时间开销是非常大的
线程执行完毕会自行销毁,如何阻止线程销毁呢,
就是不让他执行完毕----设置一个死循环
线程一直存活的话,如果一个任务运行完成可以直接执行下一个任务
流程一直获取任务,不需要新建与销毁
缺点是:一直消耗着cpu
如果不处于运行状态
流程:新建线程,获取一个任务,销毁线程--标记为无效空间,然后在新建线程
(每个任务之间都有销毁和新建)
核心线程数:就是一直处于运行状态的线程。
短时间100个 10个放核心数 剩下90个放队列里 不开启最大线程数
短时间2000个 10个核心 50个最大 1000个队列 剩下950个拒绝掉
比如: 任务每毫秒到达一个 线程需要2ms处理一个
总结2000个任务
只要10个核心线程数没有满,有了任务也会创建新的线程,而不是把他交给打空转的任务,直到核心线程数线程创建完毕,这是java规定的
如果每毫秒10个任务,而10个核心是每ms5个,处理不完的就会进入队列。
最终400ms左右处理完毕,也不会出发拒绝策略
如果每毫秒25个 80ms上传完
50ms满了我们会开启最大线程数。
过期时间 为了节省cpu性能 在一段时间后会销毁多出的线程数,只剩下核心线程数