线程池相关接口和类Future

本文介绍了Java中线程池的Future接口及其实现类FutureTask,详细解释了FutureTask如何同时作为任务执行者和返回值,并通过示例展示了如何使用FutureTask获取异步计算的结果。
                                                  线程池相关接口和类Future
package src.main.java.com.qqjx.thread;

/*
 * @Auther  wangpeng
 * @Date 2021/2/3
 */

import java.util.concurrent.*;

public class T06_00_Future {

    public static void main(String[] args) throws InterruptedException, ExecutionException {

        //继承关系  FutureTask<V> implements RunnableFuture<V>   RunnableFuture<V> extends Runnable, Future<V>
        //Runnable/Callable本之就是执行的任务 Future是执行任务的返回值
        //FutureTask既是执行的任务本身也是返回值
        FutureTask<Integer> task = new FutureTask<>(()->{
            TimeUnit.MILLISECONDS.sleep(500);
            return 1000;
        }); //new Callable () { Integer call();}

        new Thread(task).start();

        System.out.println(task.get()); //阻塞
    }
}
1000
### Java线程池Future接口使用示例 在Java并发编程环境中,`ExecutorService`不仅简化了线程管理任务提交的过程,还允许开发者通过`submit()`方法提交可返回结果的任务(即实现了`Callable<V>`接口的对象),并获得一个代表此任务的`Future<V>`对象[^1]。 当调用`submit(Callable<T> task)`时,如果任务成功完成,则可以从相应的`Future`实例中检索其结果。为了演示这一点,下面提供了一个简单的代码片段: ```java import java.util.concurrent.*; public class FutureExample { public static void main(String[] args) throws InterruptedException, ExecutionException { // 创建固定大小为2的线程池 ExecutorService executor = Executors.newFixedThreadPool(2); // 提交带有返回值的任务给线程池执行,并立即得到一个Future对象作为凭证 Future<Integer> futureResult = executor.submit(() -> { Thread.sleep(1000); // 模拟耗时操作 return 42; }); System.out.println("Task submitted..."); // 判断任务是否已完成 while (!futureResult.isDone()) { System.out.println("Waiting for the result..."); Thread.sleep(500); } try { Integer result = futureResult.get(); // 获取计算后的最终结果 System.out.println("The answer is " + result); } catch (ExecutionException e) { System.err.println("Error occurred during execution."); } finally { executor.shutdown(); } } } ``` 上述程序展示了如何利用`Future`来跟踪由线程池处理的任务状态及其输出。值得注意的是,在尝试获取结果之前应该先确认任务确实已经结束,因为`get()`会在必要时等待直至任务完成[^2]。 此外,还可以看到`FutureTask`的作用——它可以充当既能够被执行又能用来查询进度或取消未决工作的组件。不过在这个例子中并没有直接涉及`FutureTask`的具体实现细节[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值