FutureTask类

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"); } }



posted on   yjbjingcha  阅读(288)  评论(0编辑  收藏  举报

编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示