doc

由来

在JDK中,提供了Executors用于创建自定义的线程池对象ExecutorService,但是考虑到线程池中存在众多概念,这些概念通过不同的搭配实现灵活的线程管理策略,单独使用Executors无法满足需求,构建了ExecutorBuilder

概念

线程池对待线程的策略

  1. 如果池中任务数 < corePoolSize -> 放入立即执行
  2. 如果池中任务数 > corePoolSize -> 放入队列等待
  3. 队列满 -> 新建线程立即执行
  4. 执行中的线程 > maxPoolSize -> 触发handler(RejectedExecutionHandler)异常

workQueue线程池策略

使用

  1. 默认线程池

策略如下:

ExecutorService executor = ExecutorBuilder builder = ExecutorBuilder.create()..build();
  1. 单线程线程池
ExecutorService executor = ExecutorBuilder.create()//
	.setCorePoolSize(1)//
	.setMaxPoolSize(1)//
	.setKeepAliveTime(0)//
	.build();
  1. 更多选项的线程池
ExecutorService executor = ExecutorBuilder.create()
	.setCorePoolSize(5)
	.setMaxPoolSize(10)
	.setWorkQueue(new LinkedBlockingQueue<>(100))
	.build();
  1. 特殊策略的线程池
ExecutorService executor = ExecutorBuilder.create()
	.setCorePoolSize(5)
	.setMaxPoolSize(10)
	.useSynchronousQueue()
	.build();