赞
踩
在Java并发编程中,FutureTask
是一个非常有用的类,它充当了Thread
和Callable
之间的适配器。FutureTask
实现了Runnable
接口,并且实现了Future
接口,这使得它既可以被Thread
执行,也可以提供对异步计算结果的访问。
FutureTask
的主要作用是将Callable
的异步计算结果封装起来,并且提供了一种机制来等待这些结果。它还允许取消计算、查询计算是否完成以及检索计算结果。
在Java中,Callable
和Runnable
都是用来表示一个可以被线程执行的任务,但它们之间存在一些关键区别:
Runnable
:不返回任何值,也没有明确的异常处理机制。Callable<V>
:可以返回一个结果,并且可以抛出异常。它返回一个Future<V>
类型的对象,可以通过这个对象获取计算结果。当你有一个Callable
任务并且希望在Thread
中执行它时,你可以创建一个FutureTask
实例并将Callable
传入。这样,你就可以像使用Runnable
一样使用FutureTask
,并通过Thread
来执行它。
创建FutureTask
实例的基本步骤如下:
Callable
任务。Callable
任务传入FutureTask
的构造函数。Thread
并传入FutureTask
实例。Thread
的start()
方法来启动线程。下面是一个使用FutureTask
的示例:
import java.util.concurrent.Callable; import java.util.concurrent.FutureTask; public class FutureTaskExample { public static void main(String[] args) { // 创建Callable任务 Callable<Integer> callable = () -> { int sum = 0; for (int i = 1; i <= 100; i++) { sum += i; } return sum; }; // 创建FutureTask FutureTask<Integer> futureTask = new FutureTask<>(callable); // 创建并启动Thread Thread thread = new Thread(futureTask); thread.start(); try { // 获取计算结果 int result = futureTask.get(); System.out.println("The result is: " + result); } catch (Exception e) { e.printStackTrace(); } } }
在这个示例中,我们定义了一个Callable
任务,它计算从1到100的整数之和。然后,我们创建了一个FutureTask
实例,并将Callable
任务传给了它。接着,我们创建了一个Thread
并将FutureTask
传给了它。最后,我们调用了Thread
的start()
方法来启动线程,并通过调用futureTask.get()
来等待并获取计算结果。
FutureTask
继承自AbstractQueuedSynchronizer
并实现了Runnable
和Future
接口,因此它提供了以下方法:
run()
:执行Callable
任务。get()
:阻塞等待并返回Callable
任务的结果。get(long timeout, TimeUnit unit)
:在给定时间内等待结果。cancel(boolean mayInterruptIfRunning)
:尝试取消计算。isCancelled()
:检查任务是否被取消。isDone()
:检查任务是否完成。FutureTask
提供了一个方便的方式来将Callable
任务转换为可以在Thread
中执行的形式。通过使用FutureTask
,你可以轻松地执行异步任务并等待结果。这对于需要执行耗时计算或后台任务的场景非常有用。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。