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中如何显示当前线程的所有堆栈帧?的详细内容,更多请关注编程之家其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。