异步任务
Future获取异步任务结果
利用 Java 并发包提供的 Future 可以很容易获得异步任务的执行结果,无论异步任务是通过线程池 ThreadPoolExecutor 执行的,还是通过手工创建子线程来执行的。利用多线程可以快速将一些串行的任务并行化,从而提高性能;如果任务之间有依赖关系,比如当前任务依赖前一个任务的执行结果,这种问题基本上都可以用 Future 来解决。
其类结构如下:
public interface Future<V> {
boolean cancel(boolean mayInterruptIfRunning);
boolean isCancelled();
boolean isDone();
V get() throws InterruptedException, ExecutionException;
V get(long timeout, TimeUnit unit)
throws InterruptedException, ExecutionException, TimeoutException;
}
复制代码
方法解释如下:
Future | 备注 |
---|---|
cancel(boolean) | 尝试取消异步任务的执行。如果任务已经执行完成、已经被取消、因为某种原因不能被取消,则返回false;如果任务正在执行,并且mayInterruptIfRunning为true,那么会调用interrupt()尝试打断任务。该方法返回结果后,isDone()总会返回true |
isCancelled() | 如果在任务完成前被取消,返回true |
isDone() | 如果任务完成则返回true。任务完成包括正常结束、任务被取消、任务发生异常,都返回true |
get() | 获取异步任务执行结果,如果没有返回,则阻塞等待 |
get(long timeout, TimeUnit unit) | 在给定的时间内等待获取异步任务结果,如果超时还未获取到结果,则会抛出TimeoutException |
但它本身只是一个接口,还需要看Future
的具体实现类:
红色框起来的就是常见的实现类,就不一一展开赘述了,这里以FutureTask
的使用为例:
//初始化一个线程池
ExecutorService executor = = Executors.newSingleThreadExecutor();
//new 一个Callable并传入FutureTask
FutureTask<String> future =new FutureTask<>(new Callable<String>() {
public String call() {
//do something
return result;
}});
executor.execute(future);
//在异步任务执行期间可以做一些其他的事情
displayOtherThings();
//通过future.get()得到异步任务执行结果
String result=future.get();
复制代码
CompletableFuture异步编程
CompletableFuture的线程池之坑
CompletableFuture又是如何创建新线程的?答案是ForkJoinPool.commonPool() ,我们熟悉的老朋友又回来了,还是它。当需要新的线程时,CompletableFuture会