java8 之后使用CompletableFuture来异步执行任务的场景越来越多,这个时候debug调试就是个问题了。
我们只能看到新线程之后的调用栈,一个方法各种异步都可以调用,如果不知道前面的调用栈,是非常难排查问题的。
public class CompletableFutureExample {
public static void main(String[] args) throws ExecutionException, InterruptedException {
wrap();
}
public static void wrap() {
CompletableFuture<Void> run = CompletableFuture.runAsync(() -> {
process();
});
}
public static void process() {
System.out.println("run"); // 这里设置断点
}
}
debug截图:
从截图上我们是看不到完整的调用链的。
idea 2017之后提供了一个看异步调用栈的功能,非常的好用。
开启异步调用栈:
开启后的效果:
可以看到从main方法的入口了。