1、Future的出现原因
我们在Java线程池ThreadPoolExecutor详解中利用execute(Runnable r)方法来异步执行任务,但是有一个缺点,就是无法执行带有返回值的任务。
所以引入了Future来解决这个问题。
2、Future详解
Future中有5个方法:
1、cancel():取消任务
2、isCancelled():任务是否取消成功
3、isDone():任务是否完成了
4、get():获取返回值,阻塞
5、get(long count,TimeUnit):按照count个unit超时时间来获取返回值,阻塞
ThreadPoolExecutor提供了三个方法,来获取返回值
1、submit(Runnable r)
因为Runnable的run方法是void的,没有返回值,所以Future.get()是null。
源码
static final class RunnableAdapter<T> implements Callable<T> {
final Runnable task;
final T result;
RunnableAdapter(Runnable task, T result) {
this.task = task;
this.result = result;
}
public T call() {
task.run();
return result;
}
}
将runnable封装为一个自定义的Callable对象,result为null,具体的流程可以看最底下的源码。
2、submit(Runnable r,T result)
T result就是传入的对象。我们可以通过自定义Runnable来将result传入到自定义的Runnable中,在run()方法中对结果写入到result中。其中返回的对象future.get()==result。
例子如下:
public class TestThreadExecutor {
public static void main(String[] args) throws ExecutionException, InterruptedException {
BlockingQueue queue = new LinkedBlockingQueue(10);
ThreadPoolExecutor executor = new ThreadPoolExecutor(4,10,2,TimeUnit.SECONDS,queue);
//设置coreThread如果超时也会被取消
executor.allowCoreThreadTimeOut(true);
int[] a