Exrcutor
Executors是一个Java中的工具类。提供工厂方法来创建不同类型的线程池。如下所示:
- newFixedThreadPool(int nThreads):创建固定数目线程的线程池。
- newCachedThreadPool():创建一个可缓存的线程池,调用execute将重用以前构造的线程(如果线程可用)。如果没有可用的线程,则创建一个新线程并添加到线程池中。终止并从缓存中移除那些已有60秒钟未被使用的线程。
- newSingleThreadExecutor():创建一个单线程化的Executor。
- newScheduledThreadPool(int corePoolSize):创建一个支持定时及周期性的任务执行的线程池,多数情况下可用来替代Timer类。
为什么不用
- FixedThreadPool和SingleThreadPool:允许的阻塞队列长度为Integer.MAX_VALUE,可能会堆积大量的请求,从而导致OOM。
- CachedThreadPool和ScheduledThreadPool:允许的创建线程数量为Integer.MAX_VALUE,可能会创建大量的线程,从而导致OOM。
- 真正导致OOM的其实是LinkedBlockingQueue.offer方法:Java中的BlockingQueue主要有两种实现,分别是ArrayBlockingQueue和LinkedBlockingQueue。
- ArrayBlockingQueue是一个用数组实现的有界阻塞队列,必须设置容量。
- LinkedBlockingQueue是一个用链表实现的有界阻塞队列,容量可以选择进行设置,不设置的话,将是一个无边界的阻塞队列,最大长度为Integer.MAX_VALUE.
正确创建
以自己直接调用ThreadPoolExecutor的构造函数来自己创建线程池,在创建的同时,给BlockQueue指定容量
参考链接:https://blog.csdn.net/ARPOSPF/article/details/120276045
标签:Executors,队列,创建,线程,MAX,Integer From: https://www.cnblogs.com/yliunyue/p/17230882.html