Java实现超时机制
package util;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.concurrent.*;
public class TimeoutUtil {
private static final Logger LOGGER = LoggerFactory.getLogger(TimeoutUtil.class);
private static ExecutorService executor = Executors.newSingleThreadExecutor();
public static <T> T process(Callable<T> task, long timeout) {
if (task == null) {
return null;
}
Future<T> futureRet = executor.submit(task);
try {
T ret = futureRet.get(timeout, TimeUnit.SECONDS);
return ret;
} catch (InterruptedException e) {
LOGGER.error("Interrupt Exception", e);
} catch (ExecutionException e) {
LOGGER.error("Task execute exception", e);
} catch (TimeoutException e) {
LOGGER.warn("Process Timeout");
if (futureRet != null && !futureRet.isCancelled()) {
futureRet.cancel(true);
}
}
return null;
}
}
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。