传送门:
https://www.jianshu.com/p/7e07e2d47bac
https://blog.youkuaiyun.com/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"); ...
}
}
本文详细阐述了线程池的最佳实践方法,强调了避免使用Executors创建线程池的重要性,并推荐使用ThreadPoolExecutor来精确控制线程池的行为。此外,还介绍了正确使用线程池可以有效避免资源耗尽的问题。
3482

被折叠的 条评论
为什么被折叠?



