JDK8-11-CompletableFuture(1)
Future 接口
使用 Future 接口可以接收异步任务的执行结果,可以使用线程池提交一个异步任务,然后使用 Future 接收,例如:
public class FutureTest {
public static void main(String[] args) {
//创建线程池
ExecutorService executor = Executors.newCachedThreadPool();
//线程池提交任务异步任务(接收 Callable 对象) doSomeLongComputation
Future<String> future = executor.submit(new Callable<String>() {
public String call() {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
return Thread.currentThread().getName() + " 异步任务结果";
}
});
//doSomethingElse 在异步任务执行时,主线程可以执行其他操作
System.out.println(Thread.currentThread().getName() + "线程打印。。。");
//获取异步操作的结果,如果最终被阻塞,无法得到结果,那么在最多等待1秒钟之后退出
try {
String result = future.get(1, TimeUnit.SECONDS);
System.out.println(result);
} catch (ExecutionException ee) {
// 计算抛出一个异常
ee.printStackTrace();
} catch (InterruptedException ie) {
// 当前线程在等待过程中被中断
ie.printStackTrace();
} catch (TimeoutException te) {
// 在Future对象完成之前超过已过期
te.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "执行结束");
}
}
执行结果:
main线程打印。。。
pool-1-thread-1 异步任务结果
main执行结束
main线程 与 pool-1-thread-1 线程执行过程:
由图可知 main线程 首先提交异步任务,然后执行本线程的任务(doSomethingElse ),当main线程任务执行完后,使用get方法获取异步线程执行结果,此时 异步任务 doSomeLongComputation 还未执行完成,所以 main 线程会阻塞,直到异步任务结果返回或者超时
此例引用自 Java 8 实战11.1
Future 接口的局限性
引用自 Java 8 实战11.1