随笔 - 502  文章 - 1 评论 - 6 阅读 - 37万
< 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

背景: 在做接口对接的时候,对于接口不通的情况。最好设置一个超时时间, 一个小demo记录执行异步方法的方式

 

下图4000是4秒,会导致超时

复制代码
package com.louis.z.ifs.demo;

import java.util.concurrent.*;

public class Test {
public static void main(String[] args) {
try {
ThreadPoolExecutor pool = (ThreadPoolExecutor) Executors.newFixedThreadPool(1);
FutureTask<Long> futureTask = (FutureTask<Long>) pool.submit(new Callable<Long>() {
@Override
public Long call() throws Exception {
long s = System.currentTimeMillis();
System.out.println("Callable Start");
while (!Thread.currentThread().isInterrupted()) {
if (System.currentTimeMillis() - s > 4000) {
System.out.println("Callable break;");
break;
}
}
System.out.println("Callable Over");
return System.currentTimeMillis() - s;
}
});
try {
Long r = futureTask.get(3, TimeUnit.SECONDS);
System.out.println("用时:" + r);
} catch (InterruptedException | ExecutionException | TimeoutException e) {
futureTask.cancel(true);
System.out.println("futureTask cancel");
} finally {
pool.shutdown();
System.out.println("finally");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
复制代码

结果如下

 

 ,如果时间改为2000.效果如下。

 

posted on   1161588342  阅读(1541)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2018-04-27 Liunx cannot remove `xxx': Operation not permitted
点击右上角即可分享
微信分享提示