Idea debug调试时获取异步调用栈

java8 之后使用CompletableFuture来异步执行任务的场景越来越多,这个时候debug调试就是个问题了。

我们只能看到新线程之后的调用栈,一个方法各种异步都可以调用,如果不知道前面的调用栈,是非常难排查问题的。

public class CompletableFutureExample {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        wrap();
    }
    
    public static void wrap() {
        CompletableFuture run = CompletableFuture.runAsync(() -> {
            process();
        });
    }
    
    public static void process() {
        System.out.println("run"); // 这里设置断点
    }
}

debug截图:


image.png

从截图上我们是看不到完整的调用链的。

idea 2017之后提供了一个看异步调用栈的功能,非常的好用。
开启异步调用栈:
image.png
开启后的效果:
image.png

可以看到从main方法的入口了。

异步调用栈的功能非常的好,大家都用起来吧~

你可能感兴趣的:(Idea debug调试时获取异步调用栈)