传送门:
https://www.jianshu.com/p/7e07e2d47bac
https://blog.csdn.net/qq_33764491/article/details/79129014
线程池:
1、【强制】不允许使用Executors创建线程池,而是通过ThreadPoolExecutor
的方式,让写同学更加明确线程池运行规则,避免耗尽线程资源风险
a
FixedThreadPool
和SingleThreadPool
允许的请求最大深度为Integer.MAX_VALUE
可能会堆积大量请求,导致OOMb
CacheThreadPool
和ScheduledThreadPool
允许创建最大线程数量为Integer.MAX_VALUE
可能会创建大量线程,从而导致OOM
默认使用的拒绝策略为new AbortPolicy()
A handler for rejected tasks that throws a
2、【强制】线程资源必须由线程池提供,不允许在应用中自行显示创建线程
使用线程池的好处在于减少线程的创建及销毁在系统资源的开销,解决资源不足问题。如果不使用线程池,有可能导致系统创建大量同类线程而导致消耗完内存或者“过度切换“问题。
3、【强制】创建线程或线程池请指定有意义的名称,方便出错时回溯
public class TimerTaskThread extends Thread {
public TimerTaskThread() {
super.setName("TimerTaskThread"); ...
}
}