[引用原文:https://blog.csdn.net/educast/article/details/51864912]
代码
public class ThreadTest {
public static void main(String[] args) throws InterruptedException,
ExecutionException {
final ExecutorService exec = Executors.newFixedThreadPool(1);
Callable<String> call = new Callable<String>() {
public String call() throws Exception {
//开始执行耗时操作
Thread.sleep(1000 * 5);
return "线程执行完成.";
}
};
try {
Future<String> future = exec.submit(call);
String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); //任务处理超时时间设为 1 秒
System.out.println("任务成功返回:" + obj);
} catch (TimeoutException ex) {
System.out.println("处理超时啦....");
ex.printStackTrace();
} catch (Exception e) {
System.out.println("处理失败.");
e.printStackTrace();
}
// 关闭线程池
exec.shutdown();
}
}
以上代码的允许任务最大耗时设为1秒,实际任务耗时设为5秒,则结果打印出“任务超时”。
对这两个部分:
Callable<String> call = new Callable<String>() {
public String call() throws Exception {
//开始执行耗时操作
Thread.sleep(1000 * 4);
return "线程执行完成.";
}
};
try {
Future<String> future = exec.submit(call);
String obj = future.get(1000 * 5, TimeUnit.MILLISECONDS);
//任务处理超时时间设为 1 秒
System.out.println("任务成功返回:" + obj);
}
如果把实际任务耗时改为4秒,预设最大耗时改为5秒,则可以打印出“任务成功返回”。