一、总结
有两种:
- 通过Executors工厂方法创建
- 通过new ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue)自定义创建
为什么不建议使用Executors创建线程池?
- 传入的workQueue 是一个边界为 Integer.MAX_VALUE 队列,我们也可以变相的称之为*队列了,因为边界太大了,这么大的等待队列也是非常消耗内存的
- 另外该 ThreadPoolExecutor方法使用的是默认拒绝策略(直接拒绝),但并不是所有业务场景都适合使用这个策略,当很重要的请求过来直接选择拒绝显然是不合适的
(阿里巴巴Java开发手册说明禁止使用 Executors 创建线程池),我把出处(P247)截图在此:
详情参考:日拱一兵 https://juejin.cn/post/6844904134324256775
二、两种方式demo
java中线程池创建的几种方式 https://www.cnblogs.com/jxxblogs/p/11655670.html