zoukankan      html  css  js  c++  java
  • 创建线程池的正确姿势

    小伙伴都知道通过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));

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

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

     

  • 相关阅读:
    程序媛计划——mysql连接表
    程序媛计划——mysql修改表结构
    程序媛计划——mysql 插入、查找、修改、删除数据
    程序媛计划——mysql基本操作
    程序媛计划——python爬虫
    程序媛计划——SQLite初级
    程序媛计划——python中级课时1
    Android解析XML
    Android之Widget学习总结
    Android之View和SurfaceView
  • 原文地址:https://www.cnblogs.com/Baker-Street/p/15022212.html
Copyright © 2011-2022 走看看