线程池调用
最简单情况,用户通过Executor接口来调用JDK提供的线程池调度框架。Executor接口只有一个方法execute,入参是需要执行的Runnable对象。
ExecutorService
接口继承于Executor接口,提供了对任务执行状态进行跟踪的方法。ExecutorService可以执行实现了Runnable或Callable<V>接口的任务。Callable<V>接口只有一个带V数据类型返回值的call方法,并且call方法可以抛出Exception异常。invokeAll和invokeAny执行批量任务,submit执行单个任务。
Future<V>
接口提供用户观察任务执行状态的方法。isDone判断任务是否结束。isCancelled判断任务是否被取消。cancel取消任务。get获取任务的执行结果,会抛出
InterruptedException,ExecutionException,TimeoutException异常。
CompletionService<V> 提供对Future<V>的管理。poll返回下一个已完成任务的Future,如果没有已完成任务,返回null。take和poll一样,但是当没有已完成任务,则等待。
ExecutorCompletionService实现CompletionService<V>接口,创建时需要传入Executor对象。
JDK实现
ThreadPoolExecutor
实现了ExecutorService接口,其最全构造函数ThreadPoolExecutor
(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit,BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory,RejectedExecutionHandler handler)
。
当用户给线程池新加任务时:
如果当前线程数小于corePoolSize,直接创建新的线程来执行任务
如果当前线程数大于等于corePoolSize,把任务加入等待队列
如果等待队列已满,且当前线程数小于maximunPoolSize,创建新线程来执行任务;否决抛出异常
线程处理逻辑:
执行创建线程时传入的任务
循环从等待队列中获取任务,进行执行
如果超过特定时间没有获取到任务,线程结束
Executors
newSingleThreadExecutor
corePoolSize=1
,maximumPoolSize=1,queue
Capacity=Integer.MAX_VALUE
newFixedThreadPool
corePoolSize=n
,maximumPoolSize=n,queue
Capacity=Integer.MAX_VALUE
newCachedThreadPool
corePoolSize=0,maximumPoolSize=Integer.MAX_VALUE,queue
Capacity=1