CompletableFuture.supplyAsync只是一个帮助方法,为您创建一个CompletableFuture,并将任务提交到ForkJoin池。
您可以根据您的要求创建自己的supplyAsync:
private static final ScheduledExecutorService schedulerExecutor =
Executors.newScheduledThreadPool(10);
private static final ExecutorService executorService =
Executors.newCachedThreadPool();
public static CompletableFuture supplyAsync(
final Supplier supplier, long timeoutValue, TimeUnit timeUnit,
T defaultValue) {
final CompletableFuture cf = new CompletableFuture();
// as pointed out by Peti, the ForkJoinPool.commonPool() delivers a
// ForkJoinTask implementation of Future, that doesn't interrupt when cancelling
// Using Executors.newCachedThreadPool instead in the example
// submit task
Future> future = executorService.submit(() -> {
try {
cf.complete(supplier.get());
} catch (Throwable ex) {
cf.completeExceptionally(ex);
}
});
//schedule watcher
schedulerExecutor.schedule(() -> {
if (!cf.isDone()) {
cf.complete(defaultValue);
future.cancel(true);
}
}, timeoutValue, timeUnit);
return cf;
}
使用该帮助器创建CompletableFuture与在CompletableFuture中使用静态方法一样简单:
CompletableFuture a = supplyAsync(() -> "hi", 1,
TimeUnit.SECONDS, "default");
测试:
a = supplyAsync(() -> {
try {
Thread.sleep(2000);
} catch (InterruptedException e1) {
// ignore
}
return "hi";
}, 1, TimeUnit.SECONDS, "default");
本文介绍了如何创建一个自定义的CompletableFuture.supplyAsync方法,使用指定的ExecutorService来执行任务,并添加了超时处理功能。通过示例展示了如何使用这个帮助方法创建CompletableFuture,并在超时时提供默认值。这对于实现更灵活的异步编程和错误处理很有用。
127

被折叠的 条评论
为什么被折叠?



