FutureTask类是Future 的一个实现,并实现了Runnable,
所以可通过Executor(线程池)来执行,也可传递给Thread对象执行。
如果在主线程中需要执行比较耗时的操作时,但又不想阻塞主线程时,
可以把这些作业交给Future对象在后台完成,当主线程将来需要时,
就可以通过Future对象获得后台作业的计算结果或者执行状态。
Executor框架利用FutureTask来完成异步任务,并可以用来进行任何潜在的耗时的计算。
一般FutureTask多用于耗时的计算,主线程可以在完成自己的任务后,再去获取结果。
/** * Created with IntelliJ IDEA. * User: 菜鸟大明 * Date: 14-10-23 * Time: 下午7:02 * To change this template use File | Settings | File Templates. */ public class MyCallable1 implements Callable { @Override public Object call() throws Exception { System.out.println("call"); return "end"; } public static void main(String[] args) throws ExecutionException, InterruptedException { MyCallable1 myCallable1 = new MyCallable1(); FutureTask fk = new MyFutureTask(myCallable1); // 它可以通过Thread包装来直接执行, // Thread thread = new Thread(fk); // thread.start(); // 也可以提交给ExecuteService来执行, // ExecutorService exec = Executors.newCachedThreadPool(); // Future<String> future = exec.submit(myCallable1); // 并且还可以通过v get()返回执行结果, // 在线程体没有执行完成的时候,主线程一直阻塞等待,执行完则直接返回结果。 fk.run(); System.out.println(fk.get()); } } class MyFutureTask extends FutureTask { public MyFutureTask(Callable callable) { super(callable); } // 当线程运行结束,则运行done方法。 @Override public void done() { // 此处一般用来计算任务运行耗时解析。 System.out.println("done"); } }
时间: 2025-01-02 11:23:12