Java do stuff_超时与Java 8中的默认值CompletableFuture

本文介绍了如何创建一个自定义的CompletableFuture.supplyAsync方法,使用指定的ExecutorService来执行任务,并添加了超时处理功能。通过示例展示了如何使用这个帮助方法创建CompletableFuture,并在超时时提供默认值。这对于实现更灵活的异步编程和错误处理很有用。

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");

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值