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

Exrcutor

Executors是一个Java中的工具类。提供工厂方法来创建不同类型的线程池。如下所示:

  • newFixedThreadPool(int nThreads):创建固定数目线程的线程池。
  • newCachedThreadPool():创建一个可缓存的线程池,调用execute将重用以前构造的线程(如果线程可用)。如果没有可用的线程,则创建一个新线程并添加到线程池中。终止并从缓存中移除那些已有60秒钟未被使用的线程。
  • newSingleThreadExecutor():创建一个单线程化的Executor。
  • newScheduledThreadPool(int corePoolSize):创建一个支持定时及周期性的任务执行的线程池,多数情况下可用来替代Timer类。

为什么不用

  1. FixedThreadPool和SingleThreadPool:允许的阻塞队列长度为Integer.MAX_VALUE,可能会堆积大量的请求,从而导致OOM。
  2. CachedThreadPool和ScheduledThreadPool:允许的创建线程数量为Integer.MAX_VALUE,可能会创建大量的线程,从而导致OOM。
  3. 真正导致OOM的其实是LinkedBlockingQueue.offer方法:Java中的BlockingQueue主要有两种实现,分别是ArrayBlockingQueue和LinkedBlockingQueue。
  • ArrayBlockingQueue是一个用数组实现的有界阻塞队列,必须设置容量。
  • LinkedBlockingQueue是一个用链表实现的有界阻塞队列,容量可以选择进行设置,不设置的话,将是一个无边界的阻塞队列,最大长度为Integer.MAX_VALUE.

正确创建

以自己直接调用ThreadPoolExecutor的构造函数来自己创建线程池,在创建的同时,给BlockQueue指定容量

参考链接:https://blog.csdn.net/ARPOSPF/article/details/120276045

posted @ 2023-03-18 15:30  一个苦逼的23届毕业生  阅读(17)  评论(0编辑  收藏  举报