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

Executors 是一个Java中的工具类。提供工厂方法来创建不同类型的线程池。
为什么不建议使用Executors创建线程池?_第1张图片
从上图中也可以看出,Executors的创建线程池的方法,创建出来的线程池都实现了ExecutorService接口。
为什么不建议使用Executors创建线程池?_第2张图片
可以发现,其实底层确实是通过LinkedBlockingQueue实现的:LinkedBlockingQueue是一个用链表实现的有界阻塞队列,容量可以选择进行设置,不设置的话,将是一个无边界的阻塞队列,最大长度为Integer.MAX_VALUE。如果我们不设置LinkedBlockingQueue的容量的话,其默认容量将会是Integer.MAX_VALUE。
为什么不建议使用Executors创建线程池?_第3张图片

newCachedThreadPool和newScheduledThreadPool这两种方式创建的最大线程数可能是Integer.MAX_VALUE,而创建这么多线程,就有可能导致内存溢出。

避免使用Executors创建线程池,主要是避免使用其中的默认实现,那么我们可以自己直接调用ThreadPoolExecutor的构造函数来自己创建线程池。在创建的同时,给BlockQueue指定容量就可以了。

Java ThreadPoolExecutor线程池的使用

你可能感兴趣的:(java,队列,java,多线程)