Java 多线程 - 创建线程池有哪几种方式?

一、总结

有两种:

  1. 通过Executors工厂方法创建
  2. 通过new ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue)自定义创建

 

为什么不建议使用Executors创建线程池?

  • 传入的workQueue 是一个边界为 Integer.MAX_VALUE 队列,我们也可以变相的称之为*队列了,因为边界太大了,这么大的等待队列也是非常消耗内存的
  • 另外该 ThreadPoolExecutor方法使用的是默认拒绝策略(直接拒绝),但并不是所有业务场景都适合使用这个策略,当很重要的请求过来直接选择拒绝显然是不合适的

(阿里巴巴Java开发手册说明禁止使用 Executors 创建线程池),我把出处(P247)截图在此:

 

Java 多线程 - 创建线程池有哪几种方式?

详情参考:日拱一兵 https://juejin.cn/post/6844904134324256775

 

二、两种方式demo

java中线程池创建的几种方式 https://www.cnblogs.com/jxxblogs/p/11655670.html

 

上一篇:java多线程创建方式


下一篇:forkJoin源码解读