Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Java

จะแสดงกรอบสะท้อนของ StackFrame ใน Java 9 ได้อย่างไร


มี 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