线程池调用
最简单情况,用户通过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,queueCapacity=Integer.MAX_VALUE
newFixedThreadPool
corePoolSize=n,maximumPoolSize=n,queueCapacity=Integer.MAX_VALUE
newCachedThreadPool
corePoolSize=0,maximumPoolSize=Integer.MAX_VALUE,queueCapacity=1
本文详细介绍了Java线程池的工作原理及使用方法。包括Executor接口、ExecutorService接口、Future接口和CompletionService接口的功能与实现方式。同时,还深入探讨了ThreadPoolExecutor的具体实现,以及Executors工具类提供的几种常见线程池的配置。
1486

被折叠的 条评论
为什么被折叠?



