当前位置: 首页> 房产> 建筑 > 学习分享-FutureTask

学习分享-FutureTask

时间:2025/7/15 11:16:49来源:https://blog.csdn.net/weixin_62079735/article/details/139663767 浏览次数:0次

前言

今天再改简历的时候回顾了之前实习用到的FutureTask,借此来回顾一下相关知识。

FutureTask 介绍

FutureTask 是 Java 并发包(java.util.concurrent)中的一个类,用于封装异步任务。它实现了 RunnableFuture 接口,而 RunnableFuture 接口继承了 RunnableFuture 接口。因此,FutureTask 既可以作为 Runnable 执行任务,也可以作为 Future 获取任务的结果。

主要功能
  • 任务执行:可以通过线程池或单独的线程执行 FutureTask
  • 结果获取:可以通过 Future 接口的 get 方法获取任务执行的结果。
  • 任务取消:可以通过 Future 接口的 cancel 方法取消任务的执行。
  • 任务状态查询:可以查询任务是否已经完成、是否被取消等状态。
主要方法
  • run():执行任务,当任务完成后设置其状态和结果。
  • get():等待任务执行完成,并返回结果。
  • cancel(boolean mayInterruptIfRunning):取消任务的执行。
  • isDone():检查任务是否已完成。
  • isCancelled():检查任务是否已被取消。
示例代码

以下是一个简单的 FutureTask 使用示例:

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;public class FutureTaskExample {public static void main(String[] args) {// 创建一个 Callable 任务,它返回一个字符串结果Callable<String> callableTask = () -> {Thread.sleep(2000);return "Task completed";};// 使用 FutureTask 封装 Callable 任务FutureTask<String> futureTask = new FutureTask<>(callableTask);// 创建一个单线程的线程池ExecutorService executorService = Executors.newSingleThreadExecutor();// 提交 FutureTask 给线程池执行executorService.submit(futureTask);// 主线程执行其他操作System.out.println("Main thread is doing other work...");try {// 获取 FutureTask 执行结果String result = futureTask.get();System.out.println("FutureTask result: " + result);} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}// 关闭线程池executorService.shutdown();}
}
解释
  1. 创建任务:定义一个 Callable 任务,该任务会休眠 2 秒钟,然后返回字符串 “Task completed”。
  2. 封装任务:使用 FutureTaskCallable 任务封装起来。FutureTask 实际上就是一个可以异步执行的任务对象。
  3. 提交任务:将 FutureTask 提交给线程池执行。线程池会管理任务的执行,并将执行结果存储在 FutureTask 中。
  4. 主线程工作:在任务执行期间,主线程可以继续执行其他操作,不会被阻塞。
  5. 获取结果:调用 FutureTaskget 方法来获取任务的执行结果。如果任务还未完成,get 方法会阻塞,直到任务完成并返回结果。
  6. 关闭线程池:任务完成后,关闭线程池,释放资源。

FutureTask 提供了一种将 CallableRunnable 任务封装起来的机制,使得这些任务可以被异步执行,并且可以方便地获取任务的执行结果或取消任务。这使得编写并发程序更加简洁和高效。

关键字:学习分享-FutureTask

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: