• 创建线程池的正确姿势


    小伙伴都知道通过Executors静态类可以直接创建4种类型的线程池,

    但读过阿里巴巴开发手册的童鞋一定见过这句话:

    强烈不建议直接使用Executors静态类来创建线程池!!!

    这是为啥呢? 原因如下:

    1:FixedThreadPool 和 SingleThreadPool:
    允许的请求队列(底层实现是LinkedBlockingQueue)长度为Integer.MAX_VALUE,可能会堆积大量的请求,从而导致OOM
    
    2:CachedThreadPool 和 ScheduledThreadPool
    允许的创建最大线程数量为Integer.MAX_VALUE,可能会创建大量的线程,从而导致OOM。

    说白了,避免使用Executors创建线程池,主要是避免使用其中的默认实现(可能会导致OOM),

    那么我们可以自己直接调用ThreadPoolExecutor的构造函数来自己创建线程池。在创建的同时,给BlockQueue指定容量就可以了。

    先看看它的(参数最全)构造函数:
    public ThreadPoolExecutor(int corePoolSize,
    int maximumPoolSize,
    long keepAliveTime,
    TimeUnit unit,
    BlockingQueue<Runnable> workQueue,
    ThreadFactory threadFactory,
    RejectedExecutionHandler handler) {
      ...
    }

    如下创建即可(ThreadFactory 和RejectedExecutionHandler 两个参数可以是非必传参数):
    ExecutorService executor = new ThreadPoolExecutor(10, 10, 60L, TimeUnit.SECONDS, new ArrayBlockingQueue(10));

    一张图解释下线程池的稽核核心参数:

     两张图解释下线程池的运行流程:

     

  • 相关阅读:
    滑雪在日本 之 新泻篇 7
    就算神游 之四:富士山和富士游乐园 12
    滑雪在日本 之 新泻篇 15
    就算神游 之四:富士山和富士游乐园 6
    滑雪在日本 之 新泻篇 6
    就算神游 之四:富士山和富士游乐园 13
    滑雪在日本 之 新泻篇 4
    20121022日记流水账
    滑雪在日本 之 新泻篇 8
    滑雪在日本 之 新泻篇 5
  • 原文地址:https://www.cnblogs.com/Baker-Street/p/15022212.html
Copyright © 2020-2023  润新知