CompletableFuture
是Java8新增的一个功能十分强大的工具类,它一方面实现了Future
接口,另一方面也实现了CompletionStage
接口,CompletionStage
接口多达40中方法,为我们函数式编程FutureTask
来做多任务更简洁了。
/**
* 完成了就通知我 ,手动
*
* @return
*/
public String completeNotify() {
CompletableFuture<Integer> future = new CompletableFuture<>();
threadPoolTaskExecutor.execute(new AskThread(future));
try {
Integer result = future.get();
System.out.println("result " + result);
return result.toString();
} catch (InterruptedException e) {
throw new RuntimeException(e);
} catch (ExecutionException e) {
throw new RuntimeException(e);
}
}
class AskThread implements Runnable {
CompletableFuture<Integer> future;
public AskThread(CompletableFuture<Integer> future) {
this.future = future;
}
@Override
public void run() {
int res = 0;
try {
// 模拟长时间计算过程
Thread.sleep(1000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
res = 100;
// 通知完成
future.complete(res);
}
}
public String asyncTask() {
StopWatch stopWatch = new StopWatch("asyncTask");
stopWatch.start("task");
// 如果是runAsync 没有返回值
CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> calc(50), threadPoolTaskExecutor);
CompletableFuture<Integer> futureTwo = CompletableFuture.supplyAsync(() -> calc(60), threadPoolTaskExecutor);
int result = 0;
int res = 0;
try {
result = future.get();
res = futureTwo.get();
} catch (InterruptedException e) {
throw new RuntimeException(e);
} catch (ExecutionException e) {
throw new RuntimeException(e);
}
System.out.println(result + " " + res);
stopWatch.stop();
System.out.println(stopWatch.prettyPrint());
System.out.println(stopWatch.getLastTaskTimeMillis());
return result + " " + res;
}
public int calc(int param) {
try {
// 模拟耗时
Thread.sleep(1000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
if (EXCEPTION_PARAM == param){
throw new RuntimeException("传了异常参数 "+param);
}
return param * 2;
}
public String stream() {
CompletableFuture<Void> future = CompletableFuture.supplyAsync(() -> calc(50), threadPoolTaskExecutor).
thenApply((i) -> Integer.toString(i)).
thenApply((str) -> "res " + str).
thenAccept(System.out::println);
try {
future.get();
} catch (InterruptedException e) {
throw new RuntimeException(e);
} catch (ExecutionException e) {
throw new RuntimeException(e);
}
return "done";
}
public String exception() {
CompletableFuture<Void> future = CompletableFuture.supplyAsync(() -> calc(10))
.exceptionally(ex -> {
System.out.println("异常信息 " + ex.toString());
return 0;
})
.thenApply((i) -> Integer.toString(i)).
thenApply((str) -> "res " + str).
thenAccept(System.out::println);
try {
future.get();
} catch (InterruptedException e) {
throw new RuntimeException(e);
} catch (ExecutionException e) {
throw new RuntimeException(e);
}
return "done";
}
public String compose(){
CompletableFuture future = CompletableFuture.supplyAsync(()->calc(50),threadPoolTaskExecutor)
.thenCompose((i)->CompletableFuture.supplyAsync(()->calc(i),threadPoolTaskExecutor))
.thenApply((str)->"res " + str)
.thenAccept(System.out::println);
try {
future.get();
} catch (InterruptedException e) {
throw new RuntimeException(e);
} catch (ExecutionException e) {
throw new RuntimeException(e);
}
return "done";
}
CompletableFuture
很强大,如果写异步任务相比FutureTask
更简洁。