在Java 9中如何显示当前线程的所有堆栈帧?

WBOY
WBOY 转载
2023-09-05 20:09:06 274浏览

在Java 9中如何显示当前线程的所有堆栈帧?

Stack Walking API 可以提供灵活的机制来遍历调用堆栈并提取信息,使我们能够以惰性方式过滤和访问帧。 StackWalker类是 Stack Walking API 的入口点。堆栈跟踪表示某个时间点的调用堆栈,其中每个元素代表一个方法调用。它包含从线程启动到生成的所有调用。

在下面的示例中,我们可以使用 StackWalker API 打印/显示当前线程的所有堆栈帧。

示例
import java.lang.StackWalker.StackFrame;
import java.lang.reflect.Method;
import java.util.List;
import java.util.stream.Collectors;

public class StackWalkerTest {
   public static void main(String args[]) throws Exception {
      Method test1Method = Helper1.class.getDeclaredMethod("test1", (Class[])null);
      test1Method.invoke(null, (Object[]) null);
   }
}

// Helper1 class
class Helper1 {
   protected static void test1() {
      Helper2.test2();
   }
}

// Helper2 class
class Helper2 {
   protected static void test2() {
      List<StackFrame> stack = StackWalker.getInstance().walk((s) -> s.collect(Collectors.toList()));
      for(StackFrame frame : stack) {
         System.out.println(frame.getClassName() + " " + frame.getLineNumber() + " " +    frame.getMethodName());
      }
   }
}

输出

Helper2 23 test2
Helper1 16 test1
StackWalkerTest 9 main

以上就是在Java 9中如何显示当前线程的所有堆栈帧?的详细内容,更多请关注php中文网其它相关文章!

声明:本文转载于:tutorialspoint,如有侵犯,请联系admin@php.cn删除