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 2018-03-21 03:00 yjbjingcha 阅读(288) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 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)