首页 > 文章列表 > 在Java 9中如何打印StackFrame API中的所有属性?

在Java 9中如何打印StackFrame API中的所有属性?

477 2023-09-06

StackWalker APIJava 9 中的一项新功能,它提高了前身堆栈的性能轨道元素。它还可以提供一种在异常情况下过滤堆栈元素或了解应用程序行为的方法。在 Java 9 中,访问堆栈跟踪的方式非常有限,并且一次提供整个堆栈信息。

在下面的示例中,我们需要打印堆栈帧中的所有属性

示例

import java.lang.StackWalker.StackFrame;
import java.util.*;
import java.util.stream.*;
import java.lang.StackWalker.Option;

public class AllAttributesTest {
   public static void main(String args[]) {
      System.out.println("Java 9 Stack Walker API - Print all attributes in stack frame");
      StackWalker newWalker = StackWalker.getInstance(Option.RETAIN_CLASS_REFERENCE);
      List<StackWalker.StackFrame> stackFrames = newWalker.walk(frames ->  frames.limit(1).collect(Collectors.toList()));
      stackFrames.forEach(test-> {
         System.out.printf("[Bytecode Index] %d%n", test.getByteCodeIndex());
         System.out.printf("[Class Name] %s%n", test.getClassName());
         System.out.printf("[Declaring Class] %s%n", test.getDeclaringClass());
         System.out.printf("[File Name] %s%n", test.getFileName());
         System.out.printf("[Method Name] %s%n", test.getMethodName());
         System.out.printf("[Is Native] %b%n", test.isNativeMethod());
         System.out.printf("[Line Number] %d%n", test.getLineNumber());
      });
   }
}

输出

Java 9 Stack Walker API - Print all attributes in stack frame
[Bytecode Index] 21
[Class Name] AllAttributesTest
[Declaring Class] class AllAttributesTest
[File Name] AllAttributesTest.java
[Method Name] main
[Is Native] false
[Line Number] 10