为什么不能使用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 @   一个苦逼的23届毕业生  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示