线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor的方式,这样的处理方式让写的同学更加明确线程池的运行规则,规避资源耗尽的风险。 说明:Executors各个方法的弊端:
1)newFixedThreadPool和newSingleThreadExecutor:
主要问题是堆积的请求处理队列可能会耗费非常大的内存,甚至OOM。
2)newCachedThreadPool和newScheduledThreadPool:
主要问题是线程数最大数是Integer.MAX_VALUE,可能会创建数量非常多的线程,甚至OOM。
Positive example 1:
//org.apache.commons.lang3.concurrent.BasicThreadFactory
ScheduledExecutorService executorService = new ScheduledThreadPoolExecutor(1,
new BasicThreadFactory.Builder().namingPattern("example-schedule-pool-%d").daemon(true).build());
不推荐使用Executors创建线程池,推荐通过ThreadPoolExecutor方式创建
最新推荐文章于 2024-06-02 12:56:26 发布
本文指出在Java中不应使用Executors创建线程池,因为它可能导致内存耗尽或过多线程创建的问题。建议采用ThreadPoolExecutor直接实例化,通过指定线程数量、队列容量和拒绝策略等参数,确保资源的有效管理。文中给出了三个正例,展示了如何创建线程池的正确方式。

订阅专栏 解锁全文
631

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



