线程池:
在初始化一个多线程应用程序中创建一个线程集合。 需要执行新的任务时,直接从线程集合里获取线程,不需要创建一个线程。
线程池优点:
减少创建和销毁的次数,可重复利用工作线程。
根据系统的承受能力,调整线程池中工作线程的数量,防止消耗过度内存导致服务器崩溃。
线程池组成部分:
线程池管理器,工作线程,任务队列,任务接口等。
线程池管理器:创建,销毁并管理线程,添加新任务;
工作线程: 可以循环执行任务的线程,在没有任务时进行等待;
任务队列:一种缓冲机制,将没有处理的任务放在任务队列中;
任务接口:规定任务的入口,任务执行完后收尾工作,任务执行状态。
工作线程通过该接口调度任务的执行。
线程池处理流程:
-
提交一个任务到线程池中
-
判断核心线程池是否已满
是:进入下一个流程 3
否:创建线程执行任务 -
判断队列是否已经满了
是:进入下一个流程 4
否:将任务存储在队列里 -
判断线程池是否已满
是:创建线程执行任务
否:交给饱和策略处理任务
RejectedExecutionHandler:饱和策略
AbortPolicy:直接抛出异常(默认设置)
CallerRunsPolicy:只用调用所在的线程运行任务
DiscardOldestPolicy:丢弃队列里最近的一个任务,并执行当前任务。
DiscardPolicy:不处理,丢弃掉。