java中可以通过继承Thread或者实现Runnable接口来实现多线程,但是这种方式并不能让我们在线程执行完后获取执行结果。因此在java1.5开始引入了Callable和Future接口,通过它们可以在线程执行完后获取执行结果。Callable表示一个可返回结果的任务,Future表示一个异步计算的结果
一、Callable接口
public interface Callable<V> { /** * Computes a result, or throws an exception if unable to do so. * * @return computed result * @throws Exception if unable to compute a result */ V call() throws Exception; }
二、Future接口
public interface Future<V> { //试图取消对此任务的执行。 boolean cancel(boolean mayInterruptIfRunning); //如果在任务正常完成前将其取消,则返回 true。 boolean isCancelled(); //如果任务已完成,则返回 true。 boolean isDone(); //如有必要,等待计算完成,然后获取其结果。 V get() throws InterruptedException, ExecutionException; //如有必要,最多等待为使计算完成所给定的时间之后,获取其结果(如果结果可用)。 V get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException; }
三、FutureTask
四、FutureTask的使用场景
五、FutureTask源码分析
FutureTask的实现只是依赖了一个内部类Sync实现的,Sync是AQS (AbstractQueuedSynchronizer)的子类,这个类承担了所有future的功能,AbstractQueuedSynchronizer的作者是大名鼎鼎的并发编程大师Doug Lea。
总结
1.Callable和Future代表的含义?
2.Future和FutureTask的区别?
2.FutureTask的应用场景?