JAVA自定义线程池

源码

public ThreadPoolExecutor(int corePoolSize,
                           int maximumPoolSize,
                           long keepAliveTime,
                           TimeUnit unit,
                           BlockingQueue<Runnable> workQueue,
                           ThreadFactory threadFactory,
                           RejectedExecutionHandler handler) {
	......
 }

参数含义

  • corePoolSize- 池中所保存的线程数,包括空闲线程。需要注意的是在初创建线程池时线程不会立即启动,直到有任务提交才开始启动线程并逐渐使线程数目达到corePoolSize。若想一开始就创建所有核心线程需调用prestartAllCoreThreads方法。
  • maximumPoolSize-池中允许的最大线程数。需要注意的是当核心线程满且阻塞队列也满时才会判断当前线程数是否小于最大线程数,并决定是否创建新线程。
  • keepAliveTime - 当线程数大于核心时,多于的空闲线程最多存活时间
  • unit - keepAliveTime 参数的时间单位。
  • workQueue - 当线程数目超过核心线程数时用于保存任务的队列。主要有3种类型的BlockingQueue可供选择:无界队列,有界队列和同步移交。将在下文中详细阐述。从参数中可以看到,此队列仅保存实现Runnable接口的任务。
  • threadFactory - 执行程序创建新线程时使用的工厂。
  • handler - 阻塞队列已满且线程数达到最大值时所采取的饱和策略。java默认提供了4种饱和策略的实现方式:中止、抛弃、抛弃最旧的、调用者运行。

执行策略

如果运行的线程少于corePoolSize,则 Executor始终首选添加新的线程,而不进行排队。(如果当前运行的线程小于corePoolSize,则任务根本不会存入queue中,而是直接运行)
如果运行的线程大于等于 corePoolSize,则 Executor始终首选将请求加入队列,而不添加新的线程。
如果无法将请求加入队列,则创建新的线程,除非创建此线程超出 maximumPoolSize,在这种情况下,任务将被拒绝。

三种阻塞队列

    BlockingQueue workQueue = null;
    workQueue = new ArrayBlockingQueue<>(5);//基于数组的先进先出队列,bounded(有界)
    workQueue = new LinkedBlockingQueue<>();//基于链表的先进先出队列,optionally-bounded( 可选有界 )
    workQueue = new SynchronousQueue<>();//无缓冲的等待队列,无界

任务拒接策略

RejectedExecutionHandler rejected = null;
rejected = new ThreadPoolExecutor.AbortPolicy();//中止策略,默认,队列满了丢任务抛出异常
rejected = new ThreadPoolExecutor.DiscardPolicy();//抛弃策略,抛弃策略队列满了丢任务不抛出异常
rejected = new ThreadPoolExecutor.DiscardOldestPolicy();//抛弃旧任务策略,将最早进入队列的任务删,之后再尝试加入队列
rejected = new ThreadPoolExecutor.CallerRunsPolicy();//调用者运行策略,如果添加到线程池失败,那么主线程会自己去执行该任务,主线程无法再提交新任务

  1. https://blog.csdn.net/xxj_jing/article/details/84835476
  2. https://blog.csdn.net/u011479540/article/details/51867886

你可能感兴趣的:(concurrent)