มี API มาตรฐานใน Java 9 โดยใช้ java.lang.StackWalker ระดับ. ชั้นเรียนนี้ออกแบบมาให้มีประสิทธิภาพโดยอนุญาตให้ขี้เกียจเข้าถึง ไปที่สแต็กเฟรม มีตัวเลือกอื่นๆ อีกสองสามตัวเลือกในการติดตามสแต็กที่มีการใช้งานและ/หรือเฟรมสะท้อน และสามารถเป็นประโยชน์สำหรับวัตถุประสงค์ในการดีบัก ตัวอย่างเช่น เราเพิ่ม SHOW_REFLECT_FRAMES ตัวเลือกสำหรับอินสแตนซ์ StackWalker เมื่อสร้างเพื่อให้พิมพ์เฟรมสำหรับวิธีการสะท้อนแสงเช่นกัน
ในตัวอย่างด้านล่าง เราสามารถแสดงกรอบสะท้อนของ StackFrame
ตัวอย่าง
import java.lang.StackWalker.Option;
import java.lang.StackWalker.StackFrame;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.List;
import java.util.stream.Collectors;
public class ReflectionFrameTest {
public static void main(String args[]) throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {
Method test1Method = Test1.class.getDeclaredMethod("test1", (Class[]) null);
test1Method.invoke(null, (Object[]) null);
}
}
class Test1 {
protected static void test1() {
Test2.test2();
}
}
class Test2 {
protected static void test2() {
// show reflection methods
List<StackFrame> stack = StackWalker.getInstance(Option.SHOW_REFLECT_FRAMES).walk((s) -> s.collect(Collectors.toList()));
for(StackFrame frame : stack) {
System.out.println(frame.getClassName() + " " + frame.getLineNumber() + " " + frame.getMethodName());
}
}
} ผลลัพธ์
Test2 22 test2 Test1 16 test1 jdk.internal.reflect.NativeMethodAccessorImpl -2 invoke0 jdk.internal.reflect.NativeMethodAccessorImpl 62 invoke jdk.internal.reflect.DelegatingMethodAccessorImpl 43 invoke java.lang.reflect.Method 564 invoke ReflectionFrameTest 11 main