Java可以通過使用線程來實現任務超時處理。以下是一個簡單的例子:
import java.util.concurrent.*;
public class TimeoutExample {
public static void main(String[] args) {
ExecutorService executor = Executors.newSingleThreadExecutor();
// 創建一個Callable任務
Callable<String> task = () -> {
// 模擬一個耗時的操作
Thread.sleep(5000);
return "Task completed";
};
try {
// 提交任務并設置超時時間為2秒
Future<String> future = executor.submit(task);
String result = future.get(2, TimeUnit.SECONDS);
System.out.println(result);
} catch (TimeoutException e) {
// 超時處理
System.out.println("Task timeout");
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
} finally {
executor.shutdownNow(); // 關閉線程池
}
}
}
在上面的例子中,我們創建了一個單線程的線程池,并提交了一個耗時的任務。通過Future
對象的get
方法來獲取任務的結果,并設置了超時時間為2秒。如果任務在超時時間內沒有完成,會拋出TimeoutException
,我們可以在catch塊中做相應的處理。最后,記得要調用shutdownNow
方法關閉線程池。