FutureTask实现超时任务

最近主要在弄一些c/s的东西,以及对接一些外部的接口。
记下一些感觉有用的东西吧。
java在1.5之后有Callable和Future可以获得任务执行完毕后的结果
结合ExecutorService来使用。

使用场景
在调用外部登录接口的时候发现请求过去如果没连上网会一直在请求导致登录界面死机,所以一些连接的请求必须要有一个超时时间,一些耗时的操作的时候也需要一个超时时间来防止死锁导致的资源占用。

使用方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
ExecutorService executor = Executors.newSingleThreadExecutor();
        FutureTask<PrePickupMailRes> future = new FutureTask<>(() -> {
         ...
         ...
         具体方法,返回的类可以为任意,在泛型中限制 此处返回为自用类举例
            return prePickupMailRes;
        });
 
        executor.execute(future); //执行
        try {
            PrePickupMailRes prePickupMailRes = future.get(5000, TimeUnit.MILLISECONDS); //取得结果,设置超时时间
        } catch (InterruptedException | ExecutionException | TimeoutException e) {
            future.cancel(true);
        } finally {
            executor.shutdown();
        }

  

posted @   尐鱼儿  阅读(261)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示