深入浅出Java多线程编程

线程池调用

最简单情况,用户通过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,如果没有已完成任务,返回nulltakepoll一样,但是当没有已完成任务,则等待。

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值