您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在Java中,你可以使用ExecutorService
结合Future
和Callable
来实现任务的超时控制。以下是一个简单的示例:
import java.util.concurrent.*;
Callable
接口的任务类:class MyTask implements Callable<String> {
@Override
public String call() throws Exception {
// 模拟一个耗时任务
Thread.sleep(5000);
return "任务完成";
}
}
ExecutorService
提交任务并获取Future
对象:public class TimeoutControl {
public static void main(String[] args) {
// 创建一个固定大小的线程池
ExecutorService executorService = Executors.newFixedThreadPool(1);
// 提交任务并获取Future对象
Future<String> future = executorService.submit(new MyTask());
try {
// 设置超时时间
String result = future.get(3, TimeUnit.SECONDS);
System.out.println(result);
} catch (InterruptedException e) {
System.out.println("任务被中断");
e.printStackTrace();
} catch (ExecutionException e) {
System.out.println("任务执行异常");
e.printStackTrace();
} catch (TimeoutException e) {
System.out.println("任务超时");
e.printStackTrace();
} finally {
// 关闭线程池
executorService.shutdown();
}
}
}
在这个示例中,我们创建了一个固定大小的线程池,并提交了一个实现了Callable
接口的任务。然后,我们使用future.get()
方法设置超时时间。如果在指定的时间内任务没有完成,将抛出TimeoutException
异常。最后,我们关闭线程池。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。