参考:https://www.jianshu.com/p/125ccf0046f3
一、为什么创建线程池
A、提高响应速度
B、降低创建和销毁线程的开销
C、统一管理,协同调度
二、参数
coreSize:核心线程数
maxSize:最大线程数
keepAliveTime:保活时间
TreadFactory:线程工厂,线程池类型
Handler:拒绝策略:直接抛错,不抛错忽略,忽略最老的任务等
Quence:任务队列。有界数组,无界链表,有界队列,优先级队列
三、执行原理
先打满核心线程—>再打满任务队列—>最后打满最大线程数
1.如果任务队列满了,并且最大线程数也满了,那就执行拒绝策略
2.如果任务线程执行完成,检查当前线程是否大于核心线程数,小于最大核心线程数,则进行线程销毁。如果设置了存活时间,也会看当前线程是否大于设置的存活时间,大于才销毁,要不然hold主
四、线程配置原则
1、CPU密集型:cpu个数+1
2、IO密集型:cpu个数*N. N 一般取2
3、看情况定夺,遵循公式
cpu个数*(1+w/c).
w:等待时间,可以理解为IO时间,如:DB读取,缓存读取,RPC调用
C:计算时间,可以理解为CPU活动时间,业务逻辑代码运行时间