异步编程从1.5Future到FutureTask在再到CompletableFuture,是一种进步 如下展示一个自己尝试的样例:
package futuretest;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;
import java.util.function.Function;
import java.util.function.Supplier;
public class TestCompletableFutureCallBack {
public static void main(String[] args) throws InterruptedException, ExecutionException {
CompletableFuture<String> oneFuture = CompletableFuture.supplyAsync(new Supplier<String>() {
@Override
public String get() {
try {
System.out.println("执行第一个线程中。。。耐心等待3秒");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "执行完毕第①个任务的结果";
}
});
CompletableFuture<String> twoFuture = oneFuture.thenApply(new Function<String, String>() {
@Override
public String apply(String s) {
try {
System.out.println("执行第二个线程中。。。耐心等待3秒");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return s+"+++执行完毕第②个任务的结果";
}
});
System.out.println("最终的结果: "+twoFuture.get());
}
}
输出结果为:
执行第一个线程中。。。耐心等待3秒
执行第二个线程中。。。耐心等待3秒
最终的结果: 执行完毕第①个任务的结果+++执行完毕第②个任务的结果
Process finished with exit code 0